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Editorial 



NO TODO SON Ks 



A estas alturas del año, cuando sólo nos resta por 
ver lo que pueda ofrecernos el SIMO, y ya se intuye 
la presión publicitaria de las campañas de Navidad, 
es el momento de hacer un repaso de lo que microin- 
formáticamente ha sido el año 86. 

Tanto MSX como Commodore y Sinclair parecían 
dispuestos a satisfacer la demanda de Ks de memo- 
ria que exigían los usuarios para sentir que sus má- 
quinas no se quedaban atrás en el imparable avance 
de los micros por alcanzar las capacidades mitológi- 
cas de los grandes ordenadores. Sin embargo, en es- 
tos últimos meses, los fabricantes han decidido re- 
considerar el camino que habrían de tomar sus nue- 
vos productos. 

Los que intuían una progresión geométrica de las 
capacidades de memoria, que se proyectaba así ha- 
cia el infinito, se han encontrado con que Commodo- 
re ha diseñado una bonita carcasa para su clásico 



C-64. Y que Sinclair- Alustrad, aunque ha hecho bas- 
tante más por su 128 (le ha incorporado un cassette, 
un chip de sonido y alguna cosa más) no ha supera- 
do el listón de los 128 K alcanzado el invierno pasa- 
do ni en un solo bit. Tal vez el contrapunto a esta si- 
tuación lo ponga la gran familia MSX. Su hard se ha 
desarrollado dentro de las previsiones, y según qué 
modelos, los micros de la segunda generación tienen 
memorias que están entre los 192 y los 384 Ks; la ma- 
nipulación de vídeo es una realidad y las cualidades 
gráficas son sensacionales. Sin embargo tampoco así 
hemos podido lograr toda la dicha. Aunque todas es- 
tas capacidades están ahí, falta el soft capaz de po- 
nerlas de manifiesto. De momento tendremos que 
conformarnos con los programas desarrollados para 
la primera generación y las adaptaciones de progra- 
mas de otras máquinas. 



LOS MEJORES DE INPUT 

Hemos pensado que es interesante disponer de un ranking que El resultado de las votaciones será publicado en cada número 

ponga en claro, mes a mes, cuáles son los programas preferidos de INPUT. 

de nuestros lectores. Para ello, es obligado preguntaros directamen- Entre los votantes sortearemos 10 cintas de los títulos que pidáis 

te y tener así el mejor termómetro para conocer vuestras preferen- en vuestros cupones. 

cias. Podéis votar por cualquier programa aunque no haya sido co- Nota: No es preciso que cortéis la revista, una copia hecha a 

mentado todavía en INPUT. máquina o una simple fotocopia sirven. 

Enviad vuestros votos a: LOS MEJORES DE INPUT P.° de la Castellana, 93. Planta 14. 28046 Madrid 



Primer titulo elegido L 
Tercer titulo elegido L 
Qué ordenador tienes 
1 .■ Apellido I i i 



Fecha de nacimiento L 



Dirección I i i i 



Provincia I i i i 



ELIGE TUS PROGRAMAS 

Segundo título elegido I i i i i i i i i i i i |_ 



Programa que te gustaría conseguir 
Nombre I i i i i i i i 

2.° Apellido I i i i i i l 

Teléfono I i i i i i i i 



Localidad l i i i i i i 
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MSX2; UNO HAS EN 
LA FAMILIA 



Sony ha decidido aumentar 
La familia de equipos de 
La segunda generación con 
un recién nacido, de 
inmejorable aspecto, que 
ha sido bautizado como: 
HBF 700F. 

EL aspecto externo de La 
máquina es idéntico al del 
anterior modelo segunda 
generación HB-F500P, pero 
las prestaciones son muy 
superiores. 

La memoria RAM alcanza 
nuevas cotas y se sitúa en 
un total de 384 Kbytes, 
128K dedicados al 
procesador de video y el 
resto, un total de 256K, 
destinados a los programas 
del usuario. La unidad de 
diskettes incorporada 
ofrece una capacidad de 
720 Kbytes, en formato de 
doble cara doble densidad. 

Quiza lo más interesante 
sea el software incluido 
en diskette, formado por 
un conjunto de 5 
programas: HI-BRID, una 
especie de GEM o interface 
interactivo de ventanas e 
iconos, HI-TEXT para el 
tratamiento de textos, 
HI-BASE para manejar 
archivos, HI-CALC en 
funciones de hoja 
electrónica y HI-GRAPH 
como especialista en 
gráf i eos. 

Todos estos programas se 
manejan a través del ratón 
que, por primera vez, 
viene incluido con el 
equipo. La oferta no puede 
ser más atractiva. 

*★***★★★*★**★★★★ 



STRIP POKER MSX 



Serma ha previsto para 
este mes el lanzamiento, 
en versión HSX, del 
popular "strip poker" de 
Samantha Fox, que tantos 
éxitos ha cosechado en sus 
versiones para Sinclair y 
Commodore. Por otro lado 
nos han llegado noticias 
de la firma holandesa 
Aackosoft que ha lanzado, 
bajo el titulo de Red 
Lights of Amsterdam (Las 
luces rojas de Amsterdam), 
un programa sobre el mismo 
tema, para HSX2, en el que 
se hace uso de síntesis 
vocal y de imágenes 
digitalizadas. Sin 
embargo, hasta el momento, 
no hay noticias sobre la 
posible importación de 
este soft. 

★*★★**★****★*★★★★ 



DISCO DURO PARA EL 
X 1 PRESS 



Spectravideo presentó, 
durante el último Sonimag, 
una serie de interesantes 
novedades. La más 
"salvaje" de todas fue la 
unidad de disco duro de 10 
Mbytes conectable al SVI 
738 X'Press. Esta unidad 
esta prevista para 
trabajar bajo el sistema 
operativo CP/M y saldrá 
al mercado posiblemente a 
parti r del mes de 
noviembre. Con los 10 
Megas y la velocidad del 
disco duro, con las 
características del 



X'Press (próximas a las de 
los segunda generación) y 
con el soft profesional 
que comercializa 
Spectravideo (dBASE II, 
Multiplan, etc) se puede 
empezar a pensar en 
trabajos serios desde el 
estándar MSX. 
Aparte de este Hard-Disk, 
pronto podremos disfrutar 
de un sintetizador de voz 
para MSX, que "dirá" a 
través del altavoz del 
televisor o del monitor 
cualquier frase que se nos 
ocurra y que previamente 
hayamos tecleado. El 
software del sintetizador, 
que lleva el nombre de 
Charlatán, se ofrecerá en 
cassette y diskette. 
La última novedad de la 
casa es un joystick de 
"carreras"; el Quickshot 
II Turbo. Aparte de su 
nuevo aspecto, incorpora 
mi crointerruptores en 
lugar de los clásicos 
contactos. Con ello se 
consigue una mejor 
repuesta. 

★***★★★*★***★*** 



CD ROM 



Sony y la firma americana 
Knowledgeset, dedicada a 
la edición de soft, han 
llegado a un acuerdo sobre 
un soft de gestión de CD 
ROM. El producto, de 
nombre Knowledge Retrivial 
System, permitirá la 
gestión de un CD ROM por 
parte del ordenador que 
tendrá acceso a 600 Mbytes 
de memoria de lectura. 

*★*★****★★*★★** 
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PRESTAMOS Y 
CAPITALIZACIONES 




Si alguien aún no ha pedido un prés- 
tamo a un Banco, que cruce los dedos 
o toque madera, pero sin perder la es- 
peranza... Para cuando llegue ese mo- 
mento, el programa que vamos a con- 
siderar será de gran ayuda. 

El programa vale también para 
aquellos que deseen disponer de un 
cierto capital en una fecha determina- 
da como puede ser el caso de la jubi- 
lación o ahorrar lo necesario para dar 
la entrada exigida en la compra de un 
piso. 

Tanto en uno como en otro caso es 
necesario hacer muchas cébalas y tan- 
teos, jugando con meses, número de 
plazos, intereses, etc. antes de tomar 
una decisión definitva. El ideal sería 
tener todo esto bien estudiado tran- 
quilamente en casa y llevarnos la pa- 
peleta preparada cuando acudamos al 
banco o a la Caja de Ahorros. 

En el programa PRESTAMOS Y 
CAPITALIZACIONES hemos consi- 
derado sólo aquellos casos de uso más 
frecuente, pero teniendo en cuenta 
que podemos hacer un estudio com- 
pleto en unos pocos segundos a partir 
de ciertos parámetros, no nos será di- 
fícil tantear cualquier situación por en- 
revesada que parezca. Lo que si hay 
que aclarar es que el programa no tie- 
ne en cuenta los impuestos o retencio- 
nes complementarias que hacen los 
bancos o el gobierno, como puede ser 
el IVA, comisiones, pólizas, etc. 

El programa es muy fácil de mane- 
jar a través de su Menú: 

1 - TOMA DE DATOS (CUOTA 
FIJA) 

2 - VISUALIZACION TABLA 
DE PRESTAMOS 

3 - IMPRESION TABLA DE 
PRESTAMOS 

4 - VISUALIZACION TABLA 
DE CAPITALIZACIONES 

5 - IMPRESION TABLA DE CA- 
PITALIZACIONES 



6 - TOMA DE DATOS (CUOTA 
VARIABLE) 

7 - VISUALIZACION TABLA 
CAPITALIZACIONES 

8 - IMPRESION TABLA DE CA- 
PITALIZACIONES 

Se han considerado dos situaciones: 
(1 a 5) para cuotas de amortización o 
capitalización constantes o (6 a 8) para 
porcentaje preestablecido. Con ello, 
tal como se indicaba anteriormente se 
resuelven la mayoría de los casos prác- 
ticos de una forma directa y el resto 
se puede resolver mediante unos tan- 
teos muy sencillos. 



AMORTIZACION DE PRESTAMOS 
O DEUDAS 



Cuando acudimos a un banco o 
Caja de Ahorros a solicitar un présta- 
mo deberemos fijar la cantidad desea- 
da, así como el tiempo en que preten- 
demos devolverlo y el número de pla- 
zos dentro de cada año. Por ejemplo 
600.000 ptas. en 5 años con pagos tri- 
mestrales. 

Lo normal es que los pagos sean to- 
dos iguales y por ello, este es el caso 
contemplado en el programa. Aún 
cuando todos los pagos sean iguales, 
en cada uno de ellos hay una cantidad 
que corresponde al interés que se lle- 
va el banco o entidad de crédito por 
prestarnos el dinero y la restante co- 
rresponde a la parte de capital que 
amortizamos cada vez. En cada plazo 
se paga menos intereses que en el an- 
terior y por tanto se amortiza una ma- 
yor proporción. 

El banco nos fija la cuota a pagar 
en función del tanto por ciento del in- 
terés que nos aplique. En nuestro caso 
hemos considerado que el porcentaje 
no varía a lo largo de todo el período 
de amortización. Aún cuando el pago 
pudiera ser mensual, cuando se ha- 
bla del % del interés, salvo que se in- 



dique otra cosa, se refiere a un año. 

En el primer apartado del menú 
(TOMA DE DATOS) se nos pregun- 
tan todos los datos necesarios: 

- CAPITAL DESEADO 

- INTERES ANUAL (%) 

- NUMERO DE PLAZOS 

- MESES POR PLAZO 

El programa nos dá la oportunidad 
de rectificar o reconsiderar los datos: 

DESEA MODIFICAR? S/N (para 
no modificar basta pulsar 4 N\ 4 n 4 o 
RETURN 4 ) 

Como los datos valen lo mismo para 
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definir un préstamo que una capitali- 
zación, como veremos más adelante, 
el programa nos pide que precisemos 
la operación: 

PRESTAMO / CAPITALIZ. 
(P/C)? 

El ordenador nos calcula e imprime 
en pantalla el valor de la cuota fija que 
deberemos pagar así como el total de 
intereses que habremos pagado una 
vez amortizado todo el capital presta- 
do (la verdad es que normalmente 
sólo servirá para tirarnos de los pelos 
o para forzarnos a acordarnos de los 



bancos de una manera poco ama- 
ble...). Por ejemplo si solicitamos un 
millón de pesetas a devolver en pagos 
mensuales durante cinco años y el 
banco nos pide un 18% de interés 
anual deberemos pagar cada més 
25.393 ptas. y al final habremos paga- 
do el millón que solicitamos más 
523.580 ptas. 

Si hubiéramos elegido pagar una 
vez al año en lugar de cada mes, cada 
pago sería de 319.778 ptas. con un cos- 
to de intereses de 598.890 ptas. 

Quizá nos demos cuenta que no po- 



demos pagar tanto al més y decidamos 
tantear pedir menos o pagar a más lar- 
go plazo. Basta con volver a introdu- 
cir los nuevos datos en la opción 1 y 
en unos segundos tendremos la res- 
puesta. 

La situación es análoga si queremos 
calcular los detalles de una deuda en 
la que el acreedor acepta financiarla, 
tal como sería el caso de cualquier 
«compra a plazos» (casa, coche, elec- 
trodomésticos, etc.). 

Con la opción 2 podemos visualizar 
en pantalla el desglose de cada una de 
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las cuotas, así como la deuda que nos 
queda por amortizar. Por simplicidad, 
el programa realiza un redondeo au- 
tomático a la peseta y además hace un 
reajuste en los intereses del último 
pago de forma que la amortización sea 
perfecta (se produciría una ligerísimo 
desajuste debido al redondeo que no 
añadiría mayor exactitud y produciría 
una efecto no deseado). 

Para un uso posterior quizá nos in- 
terese conservar impresos los detalles 
del cálculo e incluso confeccionar ta- 
blas con valores típicos para el caso en 
que no podamos disponer del ordena- 
dor en un cierto momento. Para ello 
existe la opción 3 que es una combi- 
nación de las dos opciones anteriores. 

Otra forma de amortización sería 
devolver el capital en parte iguales y 
pagar en cada período esta cantidad 
más los intereses devengados por la 
deuda pendiente. La cuota sería de- 
creciente cada período. El programa 
no está expresamente preparado para 
ello por considerar es de menor uso 



pero no obstante se puede calcular 
cada plazo con ayuda de la opción 1. 



FORMACION DE CAPITALES 



La capitalización es un proceso in- 
verso al de amortización de una deu- 
da. En esencia se trata de «prestar a 
un banco o entidad financiera» un di- 
nero, normalmente en forma periódi- 
ca, reinvirtiendo todos o parte de los 
intereses devengados de forma que se 
genere un aumento del capital con un 
efecto de «bola de nieve». 

Por ser de uso corriente, el progra- 
ma contempla la posibilidad de capi- 
talización a base de «cuota fija» o de 
«cuota creciente». Esta segunda forma 
se suele utilizar en las capitalizaciones 
a largo plazo (seguro de vida o jubila- 
ción) a fin de compensar los efectos de 
la inflacción. En nuestro caso se con- 
sidera que el interés del capital no va- 
ría durante todo el proceso y que el in- 
cremento de la cuota, cuando se elija 



esta fórmula, se produce de acuerdo a 
un % establecido. 

A. Capitalización con cuota fija 

La toma de datos (opción 1) es co- 
mún a la ya mencionada de amortiza- 
ción y al final nos proporciona el va- 
lor de la cuota para conseguir el capi- 
tal estipulado. 

Las opciones 4 y 5 nos permiten re- 
flejar en pantalla y en impresora los 
detalles de cada período. 

Ej. Se desea disponer de 10.000.000 
de ptas. a los 15 años haciendo apor- 
taciones mensuales iguales. 

El banco nos ofrece el 7% de inte- 
rés. 

De la opción 1 deducimos que la 
cuota debe ser de 31.367 ptas. 

B. Capitalizaciones con cuota varia- 
ble 

Las opciones 6, 7 y 8 hacen las fun- 
ciones equivalentes a 1, 4 y 5 pero con 
la variante de que se parte de una cuo- 
ta inicial incrementada anualmente se- 



EDUCATIVOS 



El estudiar no tiene por que ser pesado y una incordia , pued* ser divertido 
y una competición entre varios amigos , teniendo al ordenador como arbrito. 
Hemos lanzado al mercado una serie de programas EDUCATIVOS para 5, 6, 7, y 8 
de EGB , hecho por profesores de acuerdo a las normas del MINISTERIO 
DE EDUCACION Y CIENCIA y que resumen las editoriales mas importantes de 
esta curso. 

Dele la oportunidad a su hijo de que pueda competir contra el ordenador o 
sus propios companeros . en un programa que poco a poco le ayudara a do- 
minar los temas que esta estudiando en este curso. 

Si desea recibir mas información escribanos o llámenos por telefono . 
CATALOGO GRATUITO 

Si quieres recibir periódicamente información sobre ultimas novedades 
y articulos a la venta fotocopie o recorte este cupón y envielo. 

NOMBRE 

DIRECCION 

POBLACION D.P 

TELEFONO ORDENADOR 

CALVO ASENSIO N.8 MADRID 28015 TFNO 2431638 



COMPULAND 
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TABLA DE PRESTAMOS 



PRESTAMO 


: 1000000 PTS. 


AL: 18 % 


DE INTERES 




EN PAGOS 


DE 109666 PTS 


. CADA 3 


MES(ES) 




DURANTE 


12 PLAZOS 








PLAZO 


PARTE CAPITAL 


PARTE INTERESES DEUDA 


PENDIENTE 


1 


64666 


45000 




935334 


2 


67576 


42090 




867758 


3 


70617 


39049 




797141 


4 


73795 


35871 




723346 


5 


77115 


32551 




646231 


6 


80586 


29080 




565645 


7 


84212 


25454 




481433 


8 


88002 


21664 




393431 


9 


91962 


17704 




301469 


10 


96100 


13566 




205369 


11 


100424 


9242 




104945 


12 


104945 


4723 




0 



gún un % establecido y se obtiene el 
capital alcanzado al final del período 
fijado. Si se desea finalizar con un ca- 
pital determinado aproximado debe- 
remos hacer una serie de tanteos. 
El ordenador nos solicita: 
CUOTA INICIAL MENSUAL 
INCREMENTO ANUAL % 
NUMERO DE PLAZOS 
INTERES DEL CAPITAL % 
A continuación nos calcula: CAPI- 
TAL ALCANZADO (PTAS.) 

Ej. Se desea comenzar una capita- 
lización a 15 años con aportaciones 
mensuales comenzando con 25.000 
ptas. e incrementándolas un 8% cada 
año a fin de combatir la inflación y 
considerando que cada vez se puede 
hacer un poco más de esfuerzo econó- 
mico. 

El banco nos garantiza un interés 
del 6.5% 

Al final conseguiremos: 12.594.225 
ptas. 

Ej. Se desea disponer de 10.000.000 
de ptas., aproximadamente a los 10 
años haciendo aportaciones mensuales 
que deseamos aumentar el 10% anual 
de forma automática. 

El banco nos ofrece el 7% de inte- 
rés. 

De la opción 1 deducimos que la 
cuota inicial puede ser de: 38.100 ptas. 
para conseguir 10.010.385 ptas. o 
38.050 para alcanzar 9.997.248 ptas. 



COMO EFECTUAR LOS 
CALCULOS 



Vamos a explicar de una forma ge- 
neral los aspectos de la aritmética fi- 
nanciera que hemos utilizado en esta 
parte del programa. 

1. Amortización en cuota fijas 

Al final del primer plazo deberemos 
todo el importe del capital prestado o 
deuda contraída más los intereses de- 
vengados durante ese período. Con el 
pago de la cuota abonaremos todos los 
intereses y con el sobrante amortiza- 
remos algo del principal. 

Al final del segundo período la si- 
tuación será análoga, pero como la 
deuda será menor, también lo serán 
los intereses devengados, y al ser cons- 



tante la cuota, la reducción de la deu- 
da será mayor que en el caso anterior. 

Al final del último período nos que- 
dará una deuda tal que sumada a los 
intereses sea idéntica a la cuota esta- 
blecida, con lo cual se habrá finaliza- 
do el proceso de amortización. 

La fórmula general para el cálculo 
de capital más intereses es C*(l + 
Ip/100) donde C es el capital solicita- 
do o debido e Ip es el interés corres- 
pondiente al período elegido. Si el di- 
nero lo prestan al 18% anual y los pa- 
gos tienen una periodicidad mensual 
Ip será 18/12 = 1.5 %. 

Por simplicidad de expresión deno- 
minaremos A=(l + Ip/100) K=Cuota 
y N = N° de plazos. 



Fin Plazo No 


Deuda+Int 


1 


C*A 


2 

■ 


(C*A-K)*A 

■ • ■ • 


• 

N 





Pago Deuda Pendiente 



K OA-K 

K C*A A 2-K*A-K 

K • ■ • 

K • ■ • 

K (*) 

(*) C*A A N-K*A A (N-1)-K*A A 
(N-2) -...-K*A-K 



Considerando que la Deuda Pen- 
diente al final del último pago debe ser 
cero, y ayudándonos del Cálculo 
Combinatorio obtendremos que: 



C*Ip*(1+Ip/100) A N 

K= 

(1 + Ip/100) A N-1 



2. Capitalización con cuota fija 

Al final de cada período dispondre- 
mos del capital que teníamos acumu- 
lado, más el importe de la cuota, más 



INPUT 9 



Aplicaciones 



los intereses devengados por el total 150 
durante el período entfe plazos. 1 60 

Operando en forma semejante al 
caso anterior llegaríamos a la siguien- 
te fórmula que nos permite hallar la 
cuota necesaria para alcanzar un capi- 
tal determinado en unas condiciones 
dadas: 

C*Ip/100 

K= 

(1+Ip/100)*((1+Ip/100) A N-1) 



30 

40 
50 
60 

70 
80 
90 

100 
110 
120 
130 

140 



170 



180 



190 

Para terminar os ofrecemos el lista- 
do del programa completo. 200 



10 CLS:KEY 0FF:C0L0R 15,4,4 

: SCREEN 0:WIDTH 40 
20 G0SUB 1540 
■PRESTAMOS Y 
CAPITALIZACIONES 
'M0LIS0FT / INPUT MSX 
'VARIABLES 

'C=CAPITAL A FORMAR / 
PEDIR 

'CA=CAPITAL ACUMULADO 
'K=CU0TA PERIODICA 
'P=No.DE MESES DE CADA 
PLAZO 
'NP=No. DE PLAZOS 
' I=INTERES ANUAL EN % 
■DP=DEUDA PENDIENTE 
1 IK=PARTE INTERESES EN LA 
CUOTA 

* CK=PARTE AM0RTIZ. EN LA 
CUOTA 



210 



220 



230 



240 



250 



260 



270 



280 

290 
300 



'MENU 

CLS:PRINT TAB(5) 
"PRESTAMOS Y 
CAPITALIZACIONES": PRINT 
TAB(5) "================== 

==========" : PRINT 

PRINT"1 - TOMA DE DATOS 
(CUOTA FIJA)":PRINT 
PRINT"2 - VISUALIZACION 
TABLA DE PRESTAMOS": 
PRINT 

PRINT"3 - IMPRESION TABLA 
DE PRESTAM0S":PRINT 
PRINT"4 - VISUALIZ. TABLA 
DE CAPITALIZACI0N":PRINT 
PRINT"5 - IMPRESION TABLA 
DE CAPITALIZACI0N":PRINT 
PRINT"6 - TOMA DE DATOS 
(CUOTA VARIABLE) ":PRINT 
PRINT"7 - VISUALIZ. TABLA 
DE CAPITALIZACION":PRINT 
PRINT"8 - IMPRESION TABLA 
DE CAPITALIZACION":PRINT 
L0CATE,22:PRINT"PULSE 
OPCION DESEADA" 
P$=INKEY$:IF P$<"0" OR 
P$>"8" THEN 260 
ON VAL(P$) GOTO 280,500, 
640,850,970,1100,1320, 
1430 

REM TOMA DE DATOS (CUOTA 

FIJA ) 

CLS 

L0CATE,0: PRINT TAB(4)"=== 
DATOS PR0P0RCI0NAD0S===" 



PRINT"CAPITAL 
"TAB(20) SPACE 

PRINT"INTERES 
: "TAB(20) 

PRINT"NUMER0 
: "TAB(20) 

PRINT"MESES 
; "TAB(20) 



310 LOCATE ,3: 
(PTS.) : 
$(19) 

320 LOCATE ,5: 
ANUAL (%) 
SPACE$(19) 

330 LOCATE ,7: 
DE PLAZOS 
SPACE$(19) 

340 LOCATE ,9: 
POR PLAZO 
SPACE$(19) 

350 GOSUB 1620 : INPUT"CAPITAL 
";C:LOCATE 20,3:PRINT 
SPACE$(19) .-LOCATE 20,3: 
PRINT INT(C+.5) 

360 GOSUB 1620 : INPUVINTERES 
";I:L0CATE 20,5:PRINT 
SPACE$(19) :L0CATE 20,5: 
PRINT(INT(I*100+.5))/100 

370 GOSUB 1620 :INPUT"No. DE 
PLAZOS";NP:LOCATE 20,7: 
PRINT SPACE$(19) :L0CATE 
20,7:PRINT INT(NP+.5) 

380 GOSUB 1620 :INPUT"MESES 
POR PLAZO"; P: LOCATE 20,9: 
PRINT SPACE$(19) :L0CATE 
20,9:PRINT INT(P+.5) 

390 IP=I*P/1200:CF=(1+IP) A NP 

400 GOSUB 1620:P$="":INPUT 



"DESEA MODIFICAR S/N 
:IF P$="S" OR P$="s" 
THEN 350 
410 GOSUB 1620:P$="":INPUT 
"PRESTAMO / CAPITALIZ. ? 
(P/C) ";P$:IF P$="P" OR 



P$ 
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580 
590 
600 

610 



620 

630 
640 

650 
660 
670 



P$="p" THEN 420 ELSE 780 570 
420 REM CALCULO DE PRESTAMOS 
430 LOCATE 5 ,13:PRINT"=== 

DATOS CALCULADOS ===" 
440 LOCATE 10,15:PRINT 

"( PRESTAMOS )" 
450 K=C*IP*CF/(CF-1) :K=INT 

(K+.5) 

460 LOCATE ,17:PRINT "CUOTA 

PERIODICA (PTS)" 

TAB(22) K 
470 LOCATE ,19:PRINT "TOTAL 

INTERESES (PTS)" TABC22) 

INT(NP*K-C+.5) 
480 GOSUB 1620:PRINT"PARA 

MENU PULSE CUALQUIER 

TECLA" 

490 P$=INKEY$:IF P$="" THEN 

490 ELSE 150 
500 REM " VISUALIZACION TABLA 

DE PRESTAMOS 
510 DP=C 680 
520 FOR B=1 TO NP STEP 15 
530 CLS : PRINT TAB(8) "TABLA 

DE PRESTAMOS":PRINT 690 

TAB(8) " 

-":PRINT 
540 PRINT"PLAZ0"TAB(7) 

"PART.CAP."TAB(17) 700 

"PART. INT. "TAB(28) "DEUDA. 

PEND.":PRINT STRING$ 

(39,"="):PRINT 
550 JB=(B+14):IF JB>NP THEN 

JB=NP 

560 FOR J=B TO JB 710 



IK=DP*IP: IK=INT( IK+.5) 
:CK=K-IK:CK=INT(CK+.5) 720 
IF J=NP THEN CK=DP 730 
DP=DP-CK :DP=INT(DP+.5) 
PRINT J TAB(7) CK TABC17) 740 
IK TABÍ27) DP 750 
NEXT J :GOSUB 1620:PRINT 760 
"CUALQUIER TECLA PARA 
SEGUIR" 770 
IF INKEY$=""THEN 620 
ELSE NEXT B 780 
GOTO 150 

REM "IMPRESION TABLA DE 790 
PRESTAMOS 

DP=C 800 
FOR B=1 TO NP STEP 50 
LPRINT: LPRINT: LPRINT: 810 
LPRINT TAB(28) "TABLA DE 
PRESTAMOS": LPRINT TABC28) 820 



LPRINT 

LPRINT TAB(5) "PRESTAMO:"; 830 

C TABÍ25) "PTS. AL:";I;" 

% DE INTERES":LPRINT 

LPRINT TAB(5) "EN PAGOS DE 840 

";K; " PTS. CADA ";P; 

" MES(ES) DURANTE ";NP;" 850 

PLAZOS":LPRINT 

LPRINT TAB(8)"PLAZ0"TAB 860 
(16) "PARTE CAPITAL"TAB 870 
(32) "PARTE INTERESES"TAB 880 
(40) "DEUDA PENDIENTE": 
LPRINT TAB(8) STRING$(57, 
"=") :LPRINT 

JB=(B+49):IF JB>NP THEN 890 



JB=NP 

FOR J=B TO JB 
IK=DP*IP:IK=INT(IK+.5): 
CK=K- IK : CK= INT( CK+ .5) 
IF J=NP THEN CK=DP 
DP=DP-CK 

LPRINT TAB(8)J TAB(18) 
CK TAB(34) IK TABÍ54) DP 
NEXT J:LPRINT CHR$(12): 
NEXT B :GOTO 150 
REM CALCULO DE 
CAPITALIZACIONES 
LOCATE 5 / 13:PRINT"=== 
DATOS CALCULADOS ===" 
LOCATE 8,15:PRINT 
"< CAPITALIZACION ) 
K=C*IP/((1+IP)*(CF-1)):K= 
INTÍK+.5) 

LOCATE ,17:PRINT "CUOTA 
PERIODICA (PTS)" TAB(22) 
K 

GOSUB 1620:PRINT"PARA 
MENU PULSE CUALQUIER 
TECLA" 

P$=INKEY$:IF P$="" THEN 
840 ELSE 150 

REM VISUALIZACION TABLA 
DE CAPITALIZACIONES" 
CA=0 

FOR B=1 TO NP STEP 15 
CLS:PRINT TAB(6) "TABLA DE 
CAPITALIZACIONES": PRINT 

TAB(6) " 

":PRINT 

PRINT "PAGO No."TAB(10) 



GANADORES DE LOS MEJORES DE INPUT MSX 


En el sorteo correspondiente al número 7 
MEJORES DE INPUT han resultado ganadores: 


entre quienes escribisteis mandando vuestros votos a LOS 


NOMBRE 


LOCALIDAD 


JUEGO ELEGIDO 


Victoria Pianells Alargada 
Sergio Menéndez Font 
Gabriel Cabot Carbonell 
lago González Moro 
Juan José Ortiz Mejías 
Rafael Martín Mateos 
C. Manuel Gasols Rodríguez 
J. Luis Benítez López 
J. Manuel Romaris Martínez 
Marc Sabater Casas 


La Punta (Valencia) 
Esparraguera (Barcelona) 
Son Sardina (Baleares) 
La Coruña 
Villarreal (Castellón) 
Málaga 

H. de Uobregat (Barcelona) 
Ponferrada (León) 
S. de Compostela (Coruña) 
Sabadell (Barcelona) 


Road Fighter 
Alien 8 
Jet Fighter 
Knight Lore 
Sir Fred 
Alien 8 
Knight Lore 
Green Beret 
Profanation 
Knight Lore 



INPUT 1 1 



Aplicaciones 



"CAPITAL ACUMULADO (FIN 1010 

PLAZO) ":PRINT STRINGS 

(39,"=") : PRINT 
900 JB=(B+14):IF JB>NP THEN 1020 

JB=NP 
910 FOR J=B TO JB 
920 CA=(CA+K)*(1+IP) :CA=INT 

(CA+.5) 1030 
930 PRINT J TAB(18)USIN6 

"UtiUUUUUMUn"; CA 
940 NEXT J :G0SUB 1620: PRINT 

"CUALQUIER TECLA PARA 

SEGUIR" 1040 
950 IF INKEY$=""THEN 950 

ELSE NEXT B 1050 
960 GOTO 150 1060 
970 REM " IMPRESION TABLA DE 

CAPITALIZACIONES" 1070 
980 CA=0 

990 FOR B=1 TO NP STEP 50 1080 
1000 LPRINT rLPRINT: LPRINT: 

LPRINT TABÍ25) "TABLA DE 1090 
CAPITALIZACIONES":LPRINT 1100 

TAB(25)" 

1» . lprint 111Q 



LPRINT TAB(5)"CAPITAL:"; 
C TABC25) "PTS. AL:";I;" 
% DE INTERES":LPRINT 
LPRINT TAB(5) "EN PLAZOS 
DE ";K; " PTS. CADA ";P; 
" MES(ES) DURANTE ";NP;" 
PLAZOS":LPRINT 
LPRINT TAB(13)"PAG0 No." 
TABC26) "CAPITAL 
ACUMULADO (FINAL PLAZO)" 
:LPRINT TAB(8) STRINGS 
(57,"=") rLPRINT 
JB=(B+49):IF JB>NP THEN 
JB=NP 

FOR J=B TO JB 
CA=(CA+K)*(1+IP) :CA=INT( 
CA+.5) 

LPRINT TAB(15)J TAB(33) 
USING"##########"; CA 
NEXT J rLPRINT CHR$(12): 
NEXT B 
GOTO 150 

REM TOMA DE DATOS 
(CUOTA FIJA ) 
CLS 



1120 LOCATE, 0:PRINT TAB(4)"== 
= DATOS PROPORCIONADOS = 

1130 LOCATE ,3: PRINT"CUOTA 
INIC. MENSUAL: "TAB(20) 
SPACE$(19) 
1140 LOCATE ,5: PRINT 

"INCREMENTO ANUAL %: " 
TAB(20) SPACE$(19) 

PRINT"NUMERO 
: "TABÍ20) 



PRINT"INTERES 
:"TAB(20) 



1150 LOCATE ,7: 
DE PLAZOS 
SPACE$(19) 
1160 LOCATE ,9: 
CAPITAL(%) 
SPACE$(19) 
1170 GOSUB 1620 :INPUT"CUOTA 
INICIAL ";K:LOCATE 20,3: 
PRINT SPACE$(19) :LOCATE 
20,3:PRINT INTÍK+.5) 
1180 GOSUB 1620 :INPUT"% 

INCREMENTO ANUAL ";IC: 
LOCATE 20,5:PRINT SPACES 
(19):L0CATE 20,5:PRINT 
(INT(IC*100+.5))/100 
1190 GOSUB 1620 :INPUT"No. DE 





MULT1-GESTI0N.2 DISK 



CONTABILIDAD 



GRAPH-CALC.2 DISK 



• CONTROL DE STOCKS (9.000 ARTICULOS) • 

• CONTROL DE MINIMOS • 

• RELACION DE PEDIDOS • 

• INVENTARIOS • 

• FACTURACION — ALBARANES • 

— FACTURAS • 

— RECIBOS • 

• PRESUPUESTOS — PERSONALES • 

— CLIENTES • 

• EMISION DE PEDIDOS • 

• GESTION DE CLIENTES (500 ITEMS.) • 

• CONTABILIDAD E/S • 

• ACUMULADOR DE IVA + DEDUCCION 

• BALANCES ANUALES 

• PARA INFORMACION Y PEDIDOS: 

C/. TORROELLA DE MONTGRI, 21, ENTLO.-D 
TEL. (93) 346 84 63 - TELEX 98886 TPT-E 
08027 BARCELONA 



CONTABILIDAD GENERAL 
2.937 SUBCUENTAS 
FICHERO DE 93 CONCEPTOS 
BALANCES PRESUPUESTARIOS 
37.000 APUNTES 
HARD-COPY 

ENLAZA CON MULTI -GESTION 
PLAN CONTABLE ESPAÑOL 
PLAN RECONFIGURABLE 
LISTADOS DE CUENTAS 
LISTADOS DE SUBCUENTAS 
LISTADOS DE RESUMENES 



4¡t 



• GRAFICAS DE BARRAS 

• GRAFICAS LINEALES 

• GRAFICAS CIRCULARES 

• CONTROLES DE IMAGEN 

• HARD-COPY (2 TAMAÑOS) 

• 400 FICHEROS NUMERICOS 

• INFORMES DE FICHEROS 

• CALCULOS ESTADISTICOS 

• ENLAZA CON MULTI-GESTION 



BUSCAMOS 
DISTRIBUIDORES 
PARA TODA 
ESPAÑA 
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1200 



1210 
1220 



1230 

1240 

1250 

1260 
1270 

1280 

1290 

1300 

1310 

1320 

1330 
1340 
1350 



PLAZOS ";NP:L0CATE 20,7: 
PRINT SPACE$(19) :L0CATE 
20,7:PRINT INTÍNP+.5) 
GOSUB 1620:INPUT"INTERES 
ANUAL CAP. (%) ";I: 
LOCATE 20,9:PRINT SPACES 
(19):L0CATE 20,9:PRINT 
(INT(I*100+.5))/100 
IP=I/1200 

GOSUB 1620:P$="":INPUT 

"DESEA MODIFICAR S/N "; 

P$:IF P$="S" OR P$="s" 

THEN 1170 

REM CALCULO DE 

CAPITALIZACIONES 

LOCATE 5 ,14:PRINT"=== 

DATOS CALCULADOS ===" 

LOCATE 7,16:PRINT 

"( CAPITALIZACIONES )" 

CA=0:NK=K 

FOR L=1 TO NP STEP 12: IF 
(NP-L)=>12 THEN HB=12 
ELSE HB=(NP-L)+1 
FOR H=1 TO HB:CA=(CA+NK) 
*(1+IP):NEXT H:NK=NK* 
(1+IC/100) :NEXT L 
LOCATE ,19:PRINT"CAPITAL 
ALCANZADO (PTS)" TAB(22) 
INTÍCA+.5) 

GOSUB 1620:PRINT"PARA 
MENU PULSE CUALQUIER 
TECLA" 

P$=INKEY$:IF P$="" THEN 

1310 ELSE 150 

REM VISUALIZACION TABLA 

DE CAPITALIZACIONES" 

CA=0 : NK=K 

FOR B=1 TO NP 

IF B MOD 15<>1 THEN 1370 

ELSE CLS:PRINT " TABLA 

DE CAPITALIZACIONES 

(CUOTA VAR.)":PRINT " 



1360 PRINT 



"¡PRINT 

"PAGO No."TAB(10) 



1370 
1380 

1390 
1400 
1410 

1420 
1430 



1440 
1450 
1460 



1470 



1480 



"CUOTA" TAB(20) "CAPITAL 1490 

ACUMULADO":PRINT STRINGS 

(39,"=") :PRINT 

IF B>1 AND B MOD 12 =1 

THEN NK=NK*(1+IC/100) :NK 

=INT(NK+.5) 1500 

CA=(CA+NK)*(1+IP) :PRINT 

B TAB(10)NK TAB(18) 

USING"##########"; 1510 

INT(CA+.5) 

IF B MOD 15=0 THEN 

GOSUB 1410 

NEXT B:GOSUB 1410: 

GOTO 150 1520 

GOSUB 1620:PRINT 

"CUALQUIER TECLA PARA 1530 

SEGUIR" 

IF INKEY$="" THEN 1420 1540 
ELSE RETURN 

REM IMPRESION TABLA DE 1550 
CAPITALIZACIONES (CUOTA 
VARIABLE) 1560 
CA=0 :NK=K 

FOR B=1 TO NP 1570 
IF B MOD 50O1 THEN 1500 
ELSE CLS:LPRINT:LPRINT: 
LPRINT: LPRINT TAB(15) 
"TABLA DE CAPITALIZACION 
ES (CUOTA VARIABLE)": 
LPRINT TAB(15)" 1580 

":LPRINT 1590 

LPRINT TAB(5) "CUOTA 
INICIAL DE :";K;"PTS CON 1600 
INCREMENTO ANUAL DEL "; 
IC;" % " 

LPRINT TAB(5) "PAGADERAS 
CADA MES DURANTE ";NP; 
" MESES" : LPRINT 



1610 
1620 



1630 



LPRINT TAB(12)"PAG0 No." 
TAB(28) "CUOTA" TAB(45) 
"CAPITAL ACUMULADO": 
LPRINT TAB(12) STRINGS 
(50,"=") :LPRINT 
IF B>1 AND B MOD 12 =1 
THEN NK=NK*(1+IC/100) :NK 
=INT(NK+.5) 

CA=(CA+NK)*(1+IP) :LPRINT 

TAB(16)B TAB(27) USING 

"######";NK;:LPRINT TAB 

(47) USING"##########"; 

INT(CA+.5) 

IF B MOD 50=0 THEN 

LPRINT CHR$(12) 

NEXT B: LPRINT CHR$(12): 

GOTO 150 

CLS: LOCATE ,5:PRINT 

STRING$(39,"*") 

FOR 1=1 TO 15:PRINT "*" 

TAB(38) "*":NEXT I 

LOCATE ,20:PRINT 
STRING$(39,"*") 
LOCATE 10,7:PRINT 
"PRESTAMO S": 
LOCATE 18,9:PRINT"Y": 
LOCATE 4,11:PRINT 
"CAPITALIZACI 
O N E S" 

LOCATE 10,15:PRINT 

"I N P U T M S X" 

LOCATE 20,18:PRINT 

"MoLisoft 1986" 

FOR 1=1 TO 5000: NEXT I: 

RETURN 

STOP 

LOCATE ,22:PRINT SPACES 
(39) : LOCATE, 22 : RETURN 
SAVE'TRESYCAP.BAS" 



Si se le haee difícil encontrar INPIT 
en tu kiosco habitual, 
reséñalo por adelantado, o háznoslo saber 
para que podamos remediarlo 
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INPUT 13 







■ 





RELACIONES 
LOGICAS 



Los ordenadores son capaces de eje- 
cutar millones de operaciones lógicas 
por segundo. Pero la lógica es además 
una parte fundamental de cualquier 
programa. 

Hay tres tipos de expresiones que se 
utilizan en la programación en lengua- 
je BASIC. Una gran parte de todo 
programa está constituida por opera- 
ciones aritméticas y las realizadas con 
cadenas de caracteres; sin embargo, es 
el tercer tipo de operaciones, las rea- 
lizadas con las expresiones lógicas, el 
que realmente se ocupa de la toma de 
decisiones dentro de un programa. 

Su función elemental consiste en 
evaluar si algo es «verdadero» o «fal- 
so». Las palabras y símbolos que uti- 
liza el programa para hacer esto se lla- 
man operadores (en algunos casos se 
llaman también conectores, o conecti- 
vas). 

En las expresiones lógicas se utili- 
zan dos tipos de operadores: los rela- 
ciónales (que incluyen símbolos mate- 
máticos tales como <, > e =), y los 
lógicos que forman parte del reperto- 
rio de palabras reservadas en todas las 
versiones del BASIC: AND, OR y 
NOT. El BASIC MSX dispone ade- 
más de las palabras XOR, IMP y 
EQV. 



MAYOR, IGUAL O MENOR 



Los operadores relaciónales pueden 
utilizarse incluso en los programas 
BASIC más sencillos. Las posibles 
comparaciones que se pueden llevar a 
cabo con estos operadores son: 

A > B ... A es mayor que B 

A < B ... A es menor que B 

A ^ B ... A es mayor o igual que B 

A ^ B ... A es menor o igual que B 

A = B ... A es igual que B 

A <> B ... A es diferente de B 



Habrás visto estos operadores utili- 
zados docenas de veces en los progra- 
mas de INPUT o en cualquier otra par- 
te, y aunque su utilización es múltiple, 
su valor en las pruebas condicionales 
resulta más evidente en relación con 
la sentencia IF ... THEN. Un ejemplo 
típico de esto es: 

IF A > B THEN PRINT «A ES 
MAYOR QUE B» 

En este caso, el valor de la variable 
A debe superar el valor de B para que 
se ejecute el resto de la línea. En los 
casos en que el valor de A permanez- 
ca por debajo del valor de B, el pro- 
grama se limitará a pasar a la línea si- 
guiente. Con esto es posible disponer 
de una cierta capacidad de salto con- 
dicional: si resulta un determinado 
conjunto de valores, el programa hace 
una cosa; si resulta otro conjunto de 
valores, el programa hace otra cosa 
distinta. 

Los operadores relaciónales no es- 
tán únicamente limitados a manejar 
valores numéricos; también sirven 
para comparar cadenas de caracteres. 
No obstante, hay que manejarlos con 
precaución para evitar encontrarse 
con resultados inesperados. Se debe 
tener presente que la comparación 
siempre se detiene en el número de ca- 
racteres correspondiente a la más cor- 
ta de las dos cadenas que se compa- 
ran. Así, si una de las cadenas contie- 
ne once caracteres, mientras que la 
otra sólo contiene siete, únicamente 
intervendrán en la comparación los 
primeros siete caracteres de la cadena 
más larga, comparándose con sus co- 
rrespondientes en la cadena corta. 

Los caracteres se comparan uno por 
uno y de izquierda a derecha; de aquí 
pueden surgir los resultados inespera- 
dos. En una comparación de tipo nu- 
mérico, la proposición 5 > 10 es evi- 
dentemente falsa, pero en una compa- 



■ OPERADORES RELACIONALES 



■ 


¿UNA COSA ES MAYOR, IGUAL 0 


MENOR QUE OTRA? 


■ 


OPERADORES LOGICOS 


■ 


USO DE AND, OR Y NOT 



ración entre cadenas, puedes encon- 
trarte una sentencia en la que se com- 
paren dos variables en la siguiente for- 
ma: A$ > B$. Si A$ = «5» y B$ = 
«10» el ordenador compara en primer 
lugar el carácter que figura más a la iz- 
quierda, que en este caso es un 5 en 
una de las cadenas y un 1 en la otra, 
y a continuación se para porque con- 
sidera que ya no tiene nada que com- 
parar. 

En consecuencia se obtiene un «ver- 
dadero» como resultado de la compa- 
ración, debido a que 5 es mayor que 
1 , pero el ordenador ignora los núme- 
ros restantes de la cadena más larga. 
Tienes que estar atento para no come- 
ter errores de este tipo. 

En las comparaciones entre cadenas 
de caracteres, a las letras del alfabeto 
se les supone la siguiente relación de 
orden: «A» < «B» < «C» < «D» , et- 
cétera. Pero también aquí has de te- 
ner cuidado, ya que el ordenador no 
entiende realmente lo que estos carac- 
teres significan. Lo que hace es com- 
parar los códigos correspondientes a 
cada carácter, siendo igualmente sig- 
nificativos dentro de la cadena los es- 
pacios y otros caracteres que no son 
letras, pero que disponen también de 
un código propio. Como puedes ima- 
ginarte, esto podría causar estragos en 
un programa de clasificación de cade- 
nas por orden alfabético. 

Cuando ambas cadenas contienen 
una secuencia de caracteres parcial- 
mente idéntica, se considera numéri- 
camente mayor a la cadena más larga. 
Pero observa que una cadena más cor- 
ta es considerada mayor en una expre- 
sión como la siguiente: «ABD» > 
«ABCD» ya que la comparación se 
detiene en cuanto se encuentra con la 
primera diferencia, es decir, al com- 
parar los códigos correspondientes a 
los caracteres «D» y «C». El funciona- 
miento es de hecho el mismo que se si- 
gue al asignar prioridades alfabéticas 
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en la redacción de un índice o un dic- 
cionario, en el que «para» figura an- 
tes que «paradoja», pero después de 
«pan». 

VERDADERO O FALSO 

Toda comparación produce un re- 
sultado que en realidad es un número 
entero. Cuando la comparación resul- 
ta ser falsa, el resultado es 0, mientras 
que cuando es verdadera el resultado 
es —1. Teclea este comando en modo 
directo: PRINT 6>5, 5>7 

La expresión de la izquierda es ver- 
dadera y la de la derecha falsa. En 
consecuencia obtendrás en la pantalla 
un - 1 y un 0. 

Los números enteros que obtengas 
como resultado de las comparaciones, 
puedes utilizarlos para realizar cálcu- 
los dentro de tus programas. No obs- 
tante tienes que tener cuidado de no 
intentar hacer divisiones por 0, lo que 
te daría un mensaje de error. 

OPERADORES LOGICOS 

Las palabras reservadas AND, OR 
y NOT son operadores lógicos que 
constituyen una poderosa extensión a 
la capacidad de toma de decisiones 
por medio de la sentencia IF ... 
THEN. Por ejemplo puedes poner: IF 
esto es cierto AND eso otro es cierto, 



THEN hacer una determinada cosa. 
De esta forma puedes ir construyendo 
funciones de gran complejidad. Estos 
operadores, que a veces se llaman 
también operadores booleanos (aun- 
que no debes dejarte impresionar por 
este nombre) se pueden utilizar en co- 
mandos directos o dentro de los pro- 
gramas para obtener un «valor de ver- 
dad» en condiciones de prueba que 
pueden llegar a ser muy complejas. 
De esta forma constituyen una alter- 
nativa muy cómoda a lo que en otro 
caso sería un confuso conglomerado 
de saltos condicionales a base de una 
utilización masiva de sentencias IF ... 
THEN. 

USO DE «AND» 

En su forma más simple, se puede 
considerar que el operador AND tie- 
ne el mismo significado que la conjun- 
ción española «y». En una expresión 
tal como la siguiente: 

IF V > 0 AND V < 100 THEN 
PRINT «DENTRO DE MARGE- 
NES» 

El mensaje sólo aparecerá en pan- 
talla cuando la variable V esté com- 
prendida entre 0 y 100. 

En un programa puedes Jener una 
línea como ésta: 




990 0K=-1 AND MES>5 AND 
MES>10 AND ANO1900 
AND AN0<2001 

Esta línea de programa te permiti- 
ría comprobar si una determinada fe- 
cha corresponde a un verano del siglo 
XX. 

En este caso se utiliza AND para 
realizar cuatro pruebas, cuyos resulta- 
dos deben ser todos ciertos para que 
OK siga siendo verdadera. En esta 
prueba de validación se asigna en pri- 
mer lugar, a la variable OK, el valor 
«verdadero». A continuación se impo- 
ne la condición de que MES caiga en 
el intervalo de 6 a 9, y de que AÑO 
esté entre 1901 y 2000. Pero miremos 
un poco más en detalle lo que ocurre. 
Si se cumplen todas las condiciones, 
todas las expresiones darán un valor 
verdadero. Así, de hecho la línea de 
programa se convierte en : 

990 0K=-1 AND -1 AND -1 
AND-1 AND -1 

Si ahora le añades PRINT OK, pue- 
des comprobar que el resultado es en 
efecto —1, es decir verdadero. 

USO DE «OR» 

El operador OR puede recibir una 
consideración en gran parte análoga a 
la de AND, aunque su significado es 
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diferente, como ocurre con la conjun- 
ción española «o» en su uso cotidia- 
no. También aquí observaremos su 
empleo en una sencilla línea de pro- 
grama en la que se utiliza para com- 
parar los valores de una variable: 

990 IF V=8 0R V=10 THEN 
PRINT "OK" 

El mensaje aparecerá en la pantalla 
si el valor de la variable V es 8 o 10. 

El operador OR resulta de gran uti- 
lidad cuando se comprueba la validez 
de las entradas suministradas a una 
sentencia INPUT dentro de un pro- 
grama. Si por ejemplo el programa te 
pide que introduzcas tu edad, siempre 
habrá alguien que tecleará — 10 ó 999 
con la intención de probar a ver qué 
pasa. Pero puedes solucionar el pro- 
blema de la siguiente forma: 

10 INPUT A 

20 IF A<1 0R A>120 THEN 
PRINT"P0R FAVOR NO TE 
PASES":G0T0 10 

USO DE «NOT» 

El tercer operador lógico que se uti- 
liza con frecuencia es el NOT. Es un 
poco diferente de los anteriores en el 
sentido de que sólo utiliza un argu- 
mento, es decir, sólo actúa sobre la ex- 



presión numérica o lógica que le sigue, 
a diferencia de AND y OR que actúan 
sobre la expresión que les precede y 
sobre la que les sigue, es decir son 
operadores binarios o de dos argu- 
mentos. 

Puedes utilizar NOT en un progra- 
ma como el siguiente: 
990 IF N0T(A>10) THEN 999 

En el lenguaje hablado normal, po- 
dríamos traducir la anterior expresión 
más o menos así: «Si el valor de A no 
es mayor que 10, pasa a la línea 999». 

La función lógica que realiza el ope- 
rador NOT es convertir una condición 
verdadera en falsa y viceversa. Puedes 
utilizarla pues para invertir el valor re- 
sultante de una prueba anterior. 

TABLAS DE VERDAD 

En relación con los operadores ló- 
gicos, te encontrarás con mucha fre- 
cuencia con las «tablas de verdad». 

En realidad son algo muy sencillo 
que se utiliza para dar una represen- 
tación visual de lo que ocurre cuando 
se hacen operaciones de AND y OR 
con los valores —1 y 0 (verdadero y 
falso). El operador NOT no necesita 
en realidad una tabla de verdad, ya 
que basta con invertir los valores para 
observar su efecto. 



Las tablas de verdad pueden adop- 
tar formas diferentes. Una forma típi- 
ca para el operador AND es la si- 
guiente: 

ABC 



-1 -1 -1 (LINEA 1) 

-10 0 (LINEA 2) 

0-1 0 (LINEA 3) 

0 0 0 (LINEA 4) 



El significado de la línea 1 de la ta- 
bla es el siguiente: «Si A es verdadera 
y B es verdadera, entonces C es ver- 
dadera». El significado de la línea 2 
es: «Si A es verdadera y B es falsa, en- 
tonces C es falsa». La línea 3 signifi- 
ca: «Si A es falsa y B es verdadera, en- 
tonces C es falsa». La línea 4 por su 
parte significa: «Si A y B son falsas, 
entonces C es falsa». Análogamente la 
tabla de verdad del operador OR es: 

ABC 



-1 -1 -1 

-1 0 -1 

0 -1 -1 

0 0 0 



La primera línea significa: «Si A es 
verdadera y B es verdadera, entonces 
C es verdadera». Las líneas 2 y 3 pue- 
den ser ambas interpretadas como: «Si 
A o B son verdaderas, entonces C es 
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verdadera». El significado de la línea 
4 es: «Si A y B son ambas falsas, en- 
tonces C es también falsa». 

APLICACION PRACTICA 

Aquí tienes finalmente un progra- 
ma que utiliza los operadores AND, 
OR y NOT. Se trata de una versión 
simplificada de un programa que cal- 
cula la escala correcta de salarios para 
alguien que ha solicitado un empleo: 

10 INPUT"EDAD"; EDAD 

20 INPUT M AN0S EN LA EMPRESA"; 

ONIVEL 
30 MAS18=(EDAD>=18) 
40 CUAL =(0NIVEL>=5) 
50 IF NOT MAS18 AND NOT CUAL 

THEN PRINT"N0 VALIDO" 
60 IF (NOT MAS 18 AND CUAL) 

0R (MAS18 AND NOT CUAL) 

THEN PRINT "ESCALA DE 

SALARIO UNO" 
70 IF MAS18 AND CUAL THEN 

PRINT"ESCALA DE SALARIO 
Supongamos que como respuesta a 
las dos primeras sentencias INPUT, 
tecleas 20 años de edad y cuatro en la 
empresa. Esto significa que (EDAD 
^ 18) es verdad, mientras que (ONI- 
VEL ^ 5) es falso. En consecuencia 
la persona es MAS 18 (más de 18 años) 
y NO CUAL (no cualificada). El or- 
denador encuentra enseguida este 
conjunto de condiciones en la línea 60, 



imprimiendo a continuación «ESCA- 
LA DE SALARIO UNO». Puedes 
ampliar fácilmente este programa para 
que compruebe más condiciones, por 
ejemplo si el solicitante cuenta con 
más de dos años de experiencia, o 
cualquier otra circunstancia que sea 
necesaria para el trabajo. 

OPERACIONES NUMERICAS 

El uso de los operadores lógicos no 
está únicamente limitado a las senten- 
cias IF ... THEN que acabamos de 
ver. También se pueden utilizar en al- 
gunos tipos de operaciones numéricas. 
Puede que ya las hayas visto utilizadas 
así en algún programa y a lo mejor te 
has quedado maravillado de lo que su- 
cedía. De hecho no siempre funcionan 
de la forma obvia que podría esperar- 
se. Teclea lo siguiente en modo inme- 
diato: 

PRINT 375 AND 47 
Tal vez esperas que el resultado sea 
422, o quizás 37547. Y sin embargo el 
resultado es 39. ¿Qué ha sucedido? 
Para explicarlo, tenemos que aden- 
trarnos algo más en la forma de tra- 
bajar del ordenador, a fin de entender 
el modo en que éste maneja los dos ar- 
gumentos cuyo AND se calcula. 

En principio ambas expresiones 
(375 y 47) se convierten en su equiva- 
lente binario. 



A!7| 



375 en binario es: 

0000000101110111 

Por su parte, 47 en binario es: 

0000000000101111 

A continuación la función AND 
realiza una comparación bit a bit so- 
bre los 16 bits, dando un 1 como re- 
sultado únicamente cuando hay un 1 
en el mismo bit de ambos números en 
binario. Empezando por la derecha, 
sólo los pares de bits cero, 1, 2 y 5 
cumplen esta condición. Esto da como 
resultado el número binario 
0000000000100111. 

Al volver a hacer la conversión a 
decimal, los bits 5, 2, 1 y 0 puestos a 
1 dan un valor combinado de 39; éste 
es el resultado de hacer un AND de 
375 y 47. 

Ensaya ahora el siguiente comando 
en modo directo: 

PRINT 375 OR 47 

¿A qué se debe el resultado 383 que 
se obtiene en este caso? Al realizar la 
operación con OR lógico el resultado 
de cada comparación bit a bit es 1 si 
hay un 1 en cualquiera de los bits del 
par que se compara. Observa de nue- 
vo la forma binaria de los números an- 
teriores y verás que los bits 8, 6, 5, 4, 
3, 2, 1 y 0 tienen un 1 en al menos uno 
de los bits del par. El número binario 
resultante es 0000000101 1 1 1 1 1 1 que es 
383 en decimal. 

Con el operador OR es posible ob- 
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tener el mismo valor de bits con ex- 
presiones diferentes. Por ejemplo, si 
tecleas PRINT 315 OR 75, el resulta- 
do es también 383. Si quieres puedes 
comprobarlo realizando la conversión 
de los números a forma binaria. 

El valor -1 (que se almacena como 
FFFFFFFF en hexadecimal, es decir 
un conjunto de bits que son todos 1) 
queda inalterado cuando con él se rea- 
liza una operación de OR lógico con 
otro número cualquiera. Para hacer la 
prueba, teclea el siguiente comando 
directo: 

PRINT -1 OR 375 

cuyo resultado es - 1 . 
Veamos ahora una aplicación nu- 
mérica para el operador NOT: 

PRINT NOT 10.75,NOT -11 
Los valores resultantes son —11 y 
10. Así vemos que en efecto NOT 
suma 1 al número sobre el que se apli- 
ca y a continuación cambia su signo. 
Observa que el número en punto flo- 
tante se redondea por defecto al ente- 
ro más próximo y que es posible esti- 
mar el valor real por medio de X = 
-(X + 1). De hecho este valor se con- 
vierte a un entero de cuatro bytes, cu- 
yos bits quedan invertidos. 

USO DE XOR, IMP Y EQV 



los operadores AND, OR y NOT, que 
se encuentran en casi todas las versio- 
nes de BASIC, de otros tres operado- 
res: XOR, IMP y EQV, que comen- 
tamos a continuación. 

XOR u OR exclusivo compara dos 
números binarios bit a bit. Si los dos 
bits son distintos, el resultado es ver- 
dadero, y si son iguales, falso. Uno de 
los usos más interesantes de XOR es 
el de convertir las letras mayúsculas en 
minúsculas y viceversa. Observa que 
el código ASCII de la letra A es 65, 
que en binario se escribe 
0000000001000001 y que el código de 
la letra a (minúscula) es 97: en bina- 
rio 0000000001 100001. Todas las letras 
mayúsculas tienen el 5 o bit (el 6 o dígi- 
to empezando por la derecha) a 0, 
mientras que todas las letras minúscu- 
las lo tienen a 1, y ésta es la única di- 
ferencia entre cada letra mayúscula y 
su homologa minúscula. Por tanto 
basta tener en cuenta que 

0000 0000 0100 0001 XOR 
0000 0000 0010 0000 = 

0000 0000 0110 0001 

0000 0000 0100 0010 XOR 
0000 0000 0010 0000 = 

0000 0000 0110 0010 

etc., para entender el siguiente pro- 
urama: 



10 A$=INPUT$(1) 

20 PRINT CHR$(ASC(A$)X0R 32) 

30 GOTO 10 

De esta forma introduciendo la le- 
tra A, el programa te devolverá la a, 
y, en general, introduciendo una letra 
mayúscula el programa te devuelve la 
misma letra, pero ahora minúscula, y 
viceversa. (En realidad puedes utilizar 
el operador OR para obtener el mis- 
mo resultado). 

Ya habrás observado que la tabla de 
verdad del operador XOR es: 

ABC 



-1 -1 0 
-1 0 -1 
0 -1 -1 

0 0 0 



La propiedad exclusiva de XOR es 
que si se usa dos veces, se obtiene el 
valor original: 

A XOR B XOR B = A 

Los operadores IMP y EQV son 
menos utilizados que los anteriores y 
en realidad se pueden obtener como 
combinación de ellos (lo mismo ocu- 
rre con XOR). 

La tabla de verdad de IMP es: 
ABC 



-1 -1 -1 

-10 0 

0 -1 -1 
0 0-1 
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y se puede poner en función de OR 
y NOT, como sigue: 

A IMP B = (NOT A) OR B 
El efecto de EQV es exactamente 
el opuesto de XOR. C es verdadero 
cuando A y B son verdaderos, y falso 
en caso contrario. La tabla de verdad 
de EQV es: 

ABC 



-1 -1 -1 
-10 0 
0-10 
0 0-1 



y se puede escribir en función de 
AND, OR y NOT de la siguiente for- 
ma: 

A EQV B = (A AND B) OR 
((NOT A) AND (NOT B)) 



OPERACIONES AVANZADAS CON 
BITS 

Los operadores lógicos tienen una 
función adicional en los ordenadores 
MSX como operadores bit a bit capa- 
ces de controlar las funciones del or- 
denador. Algunas posiciones de me- 
moria de los ordenadores MSX reali- 
zan funciones determinadas. Puedes 
especificar una determinada misión 
haciendo que cierta combinación par- 
ticular de bits esté a uno, haciendo, a 



la vez, que otros bits se pongan a cero. 
Los comandos utilizados en BASIC 
para controlar el contenido de la me- 
moria son POKE y PEEK. Supón que 
en la dirección 50001 tienes el núme- 
ro 55. Una instrucción típica con PO- 
KEs y PEEKs puede tener la forma: 
POKE 50001, PEEK(50001) AND 
251 

Esto hace que el bit 2 se ponga a 
cero. PEEK(55001) dará el valor 55 
(decimal), por tanto veamos que suce- 
de al ejecutar la operación AND: 

Valor 55 : 00110111 

Valor 251: 11111011 

Operando bit a bit se tiene el nú- 
mero 001 10011 (=51). Compara la an- 
tigua configuración del valor 55 con la 
del valor 51 (nuevo valor PEEK de la 
dirección 55001) y podrás ver que el 
bit 2 (tercero por la derecha) a pasa- 
do a ser 0. Puedes volver a la situa- 
ción inicial utilizando el operador OR: 

POKE 55001, PEEK (1) OR 4 

Al aplicarle al número binario 
00110011 (51) el operador OR con el 
número binario 00000100 (4) obtene- 
mos el número 00110111, que era el 
valor inicial del PEEK antes de reali- 
zar la primera operación — en otras 
palabras, el valor almacenado en la di- 
rección 55001, vuelve a valer 55. 

Puede parecerte que esto es en rea- 
lidad un poco complicado, cuando 



puedes cambiar el valor de una direc- 
ción utilizando directamente POKE 
para introducir el nuevo valor. Sin em- 
bargo, corres el riesgo de modificar 
otros bits cambiando su estado origi- 
nal. Haciendo uso del OR lógico sólo 
tienes que especificar el bit que quie- 
res poner a 1, dejando así inalterados 
los bits restantes. 

De igual forma puedes utilizar 
AND para poner a 0 uno o más bits, 
simplemente sumando los valores de- 
cimales de los bits que quieres poner 
a cero y restando la suma de 255. Así, 
para poner a 0 los bits 0 y 2 por ejem- 
plo, basta con sumar los números 1 y 
4 (00000001 y 00000100 respectiva- 
mente) y restar la suma (5) de 255. Pór 
tanto basta con que uses AND 250. 
Para volverlos a poner a 1 basta que 
hagas OR 5. 

Este procedimiento se conoce como 
enmascaramiento de bits y la diferen- 
cia con el uso directo de POKE es que 
en este caso, se cambia el valor de la 
dirección afectada por el nuevo valor, 
mientras que los operadores lógicos 
no cambian necesariamente todos los 
bits del número sino sólo los que tu 
quieras cambiar. 

Observa, por otra parte, que los 
operadores lógicos sólo trabajan con 
números enteros, es decir, con núme- 
ros dentro del rango -32768 a + 
32767. - 
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LA MEMORIA DE VIDEO DE MSX: 
LOS MODOS DE TEXTO 



Te vamos a contar todos los secretos 
de los modos de texto de tu MSX, 
SCREEN 0 y SCREEN 1, para que 
puedas hacer desde ellos todo tipo de 
diabluras, ya sea en BASIC o en len- 
guaje máquina. 

En anteriores números de INPUT 
hemos visto cómo está distribuida la 
memoria de vídeo (VRAM) en los 
modos SCREEN 2 y SCREEN 3. Ve- 
remos en esta ocasión cómo se distri- 
buye esta misma memoria en los mo- 
dos SCREEN 0 y SCREEN 1. Estos 
modos son eminentemente de texto, 
por lo que, aunque se pueden dibujar 
gráficos con ellos, estos son de muy 
baja resolución. Sin embargo son los 
modos de pantalla más utilizados y 
con lo que resulta más sencillo esta- 
blecer la comunicación con el ordena- 
dor. 

Empezaremos viendo el modo 0, 
para establecer posteriormente las 
analogías y diferencias entre éste y el 
modo 1, así como la posibilidad de 
manipular los colores y de hacer uso 
de sprites, en este último modo de 
pantalla. 



LA TABLA DE NOMBRES DE 
PATRONES EN SCREEN 0 

Esta tabla, que tiene un nombre tan 
largo, ocupa sólamente 960 bytes, y se 
ocupa de contener los datos necesarios 
para la presentación del texto en la 
pantalla. En el modo 0 podemos su- 
poner la pantalla dividida en 40 co- 
lumnas y en 24 filas, de forma que te- 
nemos en total 40 * 24 = 960 cuadros. 
Así, a cada cuadro le corresponde un 
byte de la tabla de nombres. 

En cada uno de los bytes de esta ta- 
bla hay un número que representa el 
código ASCII del carácter que debe 
aparecer en una posición determinada 
de la pantalla. 



En la figura 1 puedes ver como se 
asignan esas posiciones de memoria a 
cada cuadro de la pantalla. Si nume- 
ramos las filas de 0 a 23 y las colum- 
nas de 0 a 39, al cuadro (0,0) le co- 
rresponde el primer byte de la tabla, 
que se obtiene mediante la variable 
BASE(0) que es igual a 0. Por tanto 
al cuadro (0,0) le corresponde el byte 
0, y el número que contenga dicho 
byte es el código ASCII del carácter 
que ocupa el cuadro. Si por ejemplo 
en el byte 0 está el valor 65 (decimal), 
el carácter del cuadro (0,0) será la le- 
tra A mayúscula. En el cuadro (1,0) 
(a la derecha del anterior) estará el ca- 
rácter correspondiente al byte 1 , en el 
cuadro (2,0), el del byte 2, ... y así 
hasta el cuadro (39,0) que se corres- 
ponde con el byte 39. El siguiente cua- 
dro es el cuadro (0,1), primer cuadro 
de la segunda fila, inmediatamente de- 
bajo del cuadro (0,0), y le correspon- 
de el byte 40... Procediendo de la mis- 
ma forma, llegaremos al cuadro 
(39,23) que es el de la esquina inferior 
derecha, al que le corresponde el byte 
960 de la tabla, (figura 1). 

La instrucción WIDTH hace que se 
dejen márgenes a la izquierda y a la 
derecha, lo que significa que ha- 
brá ciertas columnas en las que no 
se escriba nada. Pero esto no hace 
que la tabla 0 sea más corta, sen- 
cillamente se ignoran los bytes co- 
rrespondientes a esas columnas. 

Veamos un ejemplo. Teclea el si- 
guiente programa: 

10 SCREEN 0 

20 WIDTH 39 

30 LOCATE 0,0 

40 PR INT M H0LA" 

50 F0R I%=0 T0 5 

60 PRINT VPEEK(I%) 

70 NEXT 1% 

Al correrlo aparecerá en la pantalla 
lo siguiente: 





HOLA 32 72 79 76 65 32 

Al dar la orden WIDTH 39 se igno- 
ra la columna de la izquierda de la 
pantalla (columna 0). Esta es la razón 
por la que el carácter que aparece en 
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el byte O es 32 (que corresponde al es- 
pacio en blanco: si en un cuadro no 
hay nada escrito, el byte corespon- 
diente de VRAM contiene el valor 
32). 

Los códigos que hay en las posicio- 
nes 1 a 4 (72,79,76,67) son los de las 





letras H,0,L y A, y por fin en el byte 
5 vuelve a haber un 32 (espacio). 

Probablemente ya hayas pensado 
que esto te permite escribir en los 
márgenes. Escribe ahora el siguiente 
programa: 



10 SCREEN 0 
20 WIDTH 20 
30 LOCATE 0,0 
40 PRINT"ANCH0=20" 
50 F0R I%=1 T0 4 
60 READ J% 
70 VPOKE I%,J% 
80 NEXT 1% 
90 DATA 72,79,76,65 

Verás aparecer en la pantalla: 

HOLA ANCHO = 20 
Ok 

Pero no podrás mover el cursor has- 
ta la región donde está escrito 
«HOLA». Sin embargo si ahora te- 
cleas CLS, sí se limpia toda la panta- 
lla. Lo que hace CLS es llenar toda la 
tabla 0 de espacios, colocando el va- 
lor 32 en cada uno de sus bytes. 

Otra cosa que podemos hacer con 
la tabla 0 es precisamente algo pareci- 
do a CLS pero sólo en un trozo de 
pantalla, por ejemplo, para dejar es- 
pacio para mensajes. Esto es similar a 
la técnica de las ventanas pero más 
simple. Supongamos que queremos 
«limpiar» sólo las 4 filas inferiores de 
la pantalla (para ello tendremos pre- 
viamente que haber eliminado la pre- 
sentación de las teclas de función ha- 
ciendo uso de KEY OFF). Con el si- 
guiente programa en BASIC puedes 
borrar desde el byte B% hasta el últi- 
mo de la pantalla. Hemos iniciado la 
rutina con la línea 60000 para que la 
puedas incluir en tus programas: 

10 KEY OFF 
20 B%=800 

60000 F0R I%=B% T0 959 
60010 VPOKE I%,32 
60020 NEXT 1% 

También podemos hacer esto me- 
diante una pequeña rutina en código 
máquina (ver rutina 1), que pasada a 
BASIC (por medio de la sentencia 
DATA de la línea 10.000) queda 
como sigue: 

10 CLEAR 200,55000! 
20 KEY OFF 
30 F0R I%=1 T0 20 
40 READ A$ 



50 P0KE 55000!+I%, 

VAL("&H"+A$) 
60 NEXT 1% 
70 DEFUSR=55001 ! 
80 P0KE 55099!, 32 
90 F0R I%=0 T0 959 
100 VPOKE I%,65 
110 NEXT 1% 
120 U=USR(800) 

10000 DATA 3A,3B,D7,21,C0,03, 
ED,4B,F8,F7,ED,42,C5,E5 
,C1,E1,CD, 56,00, C9 

El parámetro X de USR(X) (línea 
120) debe ser el primer byte a borrar, 
y la rutina borrará desde este byte has- 
ta el último de la tabla 0. Esta rutina 
llama a FILVRM que transfiere un va- 
lor a un trozo de VRAM. 

El POKE de la línea 80 indica a la 
rutina en C.M. que tiene que llenar el 
trozo de pantalla con el carácter ES- 
PACIO (código 32). 

Prueba a llenar la pantalla con ca- 
racteres y a hacer uso posteriormente, 
de estas rutinas, tanto en BASIC 
como en código máquina. 

Habrás observado que el byte co- 
rrespondiente al cuadro (x,y) viene 
dado por 

n° byte = y*40+x 

Otra aplicación útil para la tabla 0 
consiste en volcar toda la tabla en la 
memoria RAM, lo que puede ser útil, 
por ejemplo para presentar otras pan- 
tallas. La siguiente rutina en BASIC 
hace esto, transfiriendo desde el byte 
0 al 959 (último de la tabla 0) de 
VRAM a los bytes 55100 a 56059 de 
RAM. 

10 CLEAR 200,55000! 
20 SCREEN 0 
30 F0R I%=0 T0 959 
40 VPOKE I%,65 
50 NEXT 1% 

60000 F0R I%=0 T0 959 
60010 POKE 55100!+I%, 

VPEEK(I%) 
60020 NEXT 1% 

Para volver a pasar los datos de 
RAM a VRAM, puedes hacer uso de 
la siguiente rutina en BASIC 

65000 CLS 

65010 F0R I%=0 T0 959 



INPUT 23 



65020 VPOKE 1%, 

PEEK(55100!+I%) 
65030 NEXT 1% 

Verás como al correr el primer pro- 
grama se llena la pantalla con la letra 
A, y al correr el segundo, tras borrar- 
se la pantalla, vuelve a llenarse con la 
letra A (por supuesto ignorando el 
WIDTH que en ese momento hayas fi- 
jado). 

Las correspondientes rutinas en có- 
digo máquina son las rutinas 2 y 3 que 
listamos en estas páginas. El siguente 
programa BASIC las incorpora me- 
diante los DATAS de las líneas 10000 
y 11000, respectivamente. Llamamos 
a estas rutinas mediante las funciones 
USR(0) y USR1(0), respectivamente 
(líneas 130 y 160). El bucle de la línea 
150 es simplemente para poder apre- 
ciar el efecto de las rutinas. 

10 CLEAR 200,55000! 

20 KEY 0FF 

30 SCREEN 0 

40 F0R I%=1 T0 26 

50 READ A$ 

60 P0KE 55000 !+I%, 

VAL( "&H"+ A$) 
70 NEXT 1% 
80 DEFUSR=55001 ! 
90 DEFUSR1=55014! 
100 F0R 1=0 T0 959 
110 VPOKE 1,65 
120 NEXT 
130 U=USR(0) 
140 CLS 

150 F0R 1=1 T0 100:BEEP:NEXT 
160 U=USR1(0) 

10000 DATA 21 ,00,00,01 ,c0,03, 
11, 3c,d7,cd, 59,00, c9 

11000 DATA 21,3c,d7,01,c0,03, 
11,00,00,cd,5c,00,c9 

Rápido ...¿verdad? 



LA TABLA DEL GENERADOR DE 
PATRONES EN SCREEN 0 



Ya sabes que si en una posición de 
la tabla 0 escribes el número 65, en la 
posición correspondiente de la panta- 
lla aparecerá la letra A. Pero ¿cómo 
sabe el ordenador que lo que tiene que 



escribir es la letra A? En algún lugar 
deberá tener almacenado lo que debe 
escribir, es decir los caracteres ASCII. 
Pues bien, la tabla del generador de 
caracteres se ocupa de esto. Esta ta- 
bla tiene una longitud de 2048 bytes y 
puedes encontrar su dirección de co- 
mienzo mediante la variable BASE(2) 
que vale 2048. Si divides la tabla en 
grupos de 8 bytes, observarás que tie- 
ne 256 grupos, uno para cada carácter 
(figura 2). El grupo correspondiente a 
un código i comienza en la dirección: 

código i = 2048+8*i 

Así el grupo correspondiente a la le- 
tra A, cuyo código es el 65, comienza 
en: 

2048+8*65 = 2568 

y como tiene una longitud de 8 
bytes termina en el byte 2575. 

Veamos qué valores contienen estas 
posiciones. Escribe el siguiente pro- 
grama: 

10 F0R I%=2568 T0 2575 
20 PRINT VPEEK (1%) 
30 NEXT 1% 

Al ejecutarlo obtendrás los núme- 
ros 32,80,136,136,248,136,136,0. Si en 
lugar de la línea 20 escribes: 

20 PRINT BIN$( VPEEK (1%)) 

Obtendrás: 

00100000 
01010000 
10001000 
10001000 
11111000 
10001000 
10001000 
00000000 

O sea que hemos formado la letra 
A con ceros y unos. El ordenador, a 
la hora de presentar el carácter, igno- 
ra los ceros y dibuja un punto donde 
hay un uno. Por eso podemos ver la le- 
tra A como la vemos. Prueba a editar 
otros caracteres a partir de sus códi- 
gos ASCII. 

Al final del artículo incluimos un 
programa en BASIC que explicare- 
mos entonces y que te permitirá edi- 
tar todos los caracteres. 



El hecho de tener una copia de los 
caracteres en un trozo de VRAM te 
hará pensar que pueden ser modifica- 
dos. Efectivamente, observa (figura 2) 
que el último byte de la letra A con- 
tiene un 0. Lo mismo pasa con el res- 
to de los caracteres, y esto es así para 
que haya una pequeña separación en 
la pantalla entre dos caracteres que es- 
tán uno encima de otro. Escribe aho- 
ra VPOKE 2575,255 (255D = 
1111111 IB). A partir de este momen- 
to cada vez que teclees la letra A ma- 
yúscula, ésta aparecerá subrayada. 

Con el programa del final del artí- 
culo podrás modificar a tu antojo el 
juego de caracteres, y guardarlo en 
cinta o en disco. Esta posibilidad se in- 
cluye porque siempre que escribas 
SCREEN 0 el juego de caracteres se 
actualiza y vuelve a presentarse el jue- 
go inicial residente en ROM. 

Como puede que te interese hemos 
incluido aquí un pequeño programa 
que te acepta dos juegos de caracteres 
que comprenden desde el carácter 0 
hasta el 127 y sus inversos. Esto te per- 
mite escribir la letra A tal como se es- 
cribe normalmente y en negativo (el 
color de fondo pasa a ser el color de 
tinta y viceversa). Al utilizar este pro- 
grama puedes escribir con caracteres 
normales hasta que pulses la tecla de 
función Fl. A partir de entonces todo 
lo que escribas será en vídeo inverso, 
hasta que vuelvas a pulsar Fl. La cla- 
ve del programa está en la línea 30 en 
la que todos los caracteres por encima 
del 127 son modificados, de forma que 
en cada byte correspondiente al carác- 
ter de código 1% -1-127 se escribe el 
«inverso» (complemento a 255) de lo 
que hay en el byte correspondiente del 
carácter de código 1%, lo que se con- 
sigue con el XOR 255 de esa línea. 
Cuando ejecutes el programa espera 
un poco hasta que suene un BEEP ya 
que la línea 30 se ejecuta 1024 veces. 

10 F0R I%=0 T0 127 

20 F0R J%=0 T0 7 

30 VPOKE 2048+(I%+128)*8+J%, 

VPEEK(2048+I%*8+J%) 

XOR 255 
40 NEXT J% 
50 NEXT 1% 
60 BEEPrBEEP 
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70 CLS 

1000 0N KEY GOSUB 1050 

1010 KEY(1) ON 

1020 A$=INKEY$:IF A$= ,m 

THEN 1020 
1030 PRINTAS; 
1040 GOTO 1020 
1050 ON KEY GOSUB 1000 
1060 KEYC1 ) ON 
1070 A$=INKEY$:IF A$="" 

THEN 1070 
1080 PRINT CHR$(ASC(A$)+ 

128); 
1090 GOTO 1070 

Con esto hemos terminado las ta- 
blas 0 y 2 que son todas las tablas dis- 
ponibles en SCREEN 0. La tabla 0 tie- 
ne una longitud de 960 bytes y la ta- 
bla 2 de 2048, por tanto de los 16 
Kbytes= 16384 bytes de VRAM sólo 



se utilizan 3008 bytes. Quedan dispo- 
nibles 13376 bytes que podemos utili- 
zar para otras cosas, por ejemplo para 
guardar pantallas de ayuda. En un 
próximo artículo veremos como cam- 
biar el valor de BASE(0) para tener 
hasta 14 pantallas diferentes. 



LA TABLA DE NOMBRES DE 
PATRONES EN SCREEN 1 



El modo de textos de 32 columnas, 
o SCREEN l, poco se diferencia del 
de 40 columnas; al menos en princi- 
pio. En este modo no disponemos de 
40 columnas sino de 32, pero como 
esas 32 columnas ocupan también toda 
la anchura de la pantalla, cada uno de 
los cuadros correspondientes es más 
ancho que cada cuadro en el modo 0. 



Figura 1. — Tabla de nombres de 
patrones en el modo de textos de 40 
columnas. 



Por eso en SCREEN 0 hay caracteres 
que no se ven completamente. 

Podemos conocer la dirección de 
comienzo de esta tabla mediante la va- 
riable BASE (5)=6144, y como tiene 
sólo 32 x 24 cuadros (recuerda la fi- 
gura 1: en lugar de 40 columnas, te- 
nemos ahora 32), es decir 768 cuadros, 
su longiutd es precisamente esta (768 
bytes). La organización de la tabla es 
análoga a la de la tabla 0. El byte co- 
rrespondiente al cuadro (x,y) estará 
ahora en la dirección: 

byte(x,y)=6144+32*y+x 

Las aplicaciones de esta tabla son si- 
milares a las de la tabla 0. A continua- 
ción tienes la rutina que borra la pan- 



INPUT 25 



talla desde el byte B% hasta el final 
de la pantalla. 

10 KEY OFF 
20 SCREEN 1 
30 B%=640 

60000 FOR I%=BASE(5)+B% TO 

BASE(5)+767 
60010 VPOKE I%,32 
60020 NEXT 1% 

Donde puedes modificar la variable 
B% para borrar una zona mayor o me- 
nor. La rutina correspondiente en có- 
digo máquina es la rutina 4, a la que 
corresponde el siguiente programa 
BASIC: 

10 CLEAR 200,55000! 

20 KEY OFF 

30 SCREEN 1 

40 FOR I%=1 T0 20 

50 READ A$ 



60 P0KE 55000 !+I%, 

VALÍ "&H"+ A$) 
70 NEXT 1% 
80 DEFUSR=55001 ! 
90 POKE 55099! ,32 
100 FOR 1=6144 T0 6911 
110 VPOKE 1,65 
120 NEXT 
130 U=USR(6784) 
10000 DATA 3A,3B,D7,21 ,00,1b, 
ED,4B,F8,F7,ED,42,C5,E5 
,C1,E1,CD, 56,00, C9 

Aquí también el parámetro X de 
USR(X) debe ser el primer byte a bo- 
rrar, y la rutina borrará desde éste 
hasta el último de la tabla. 

Para pasar toda la tabla de VRAM 
a RAM puedes utilizar el siguiente 
programa BASIC: 

10 CLEAR 200,55000! 
20 SCREEN 1 
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30 FOR I%=0 T0 767 
40 VPOKE 61 44+1% ,65 
50 NEXT 1% 

60000 FOR I%=0 T0 767 
60010 POKE 55100!+I%, 
VPEEK(6144+I%) 
60020 NEXT 1% 

En este programa (como ocurría 
con el correspondiente a SCREEN 0), 
la pantalla se llena con la letra A y lue- 
go la tabla se coloca entre las posicio- 
nes 55100 y 55867 de RAM. Para vol- 
ver a pasar los datos de RAM a 
VRAM utiliza la siguiente rutina en 
BASIC: 

65000 CLS 

65010 FOR I%=0 T0 767 
65020 VPOKE 6144+1%, PEEK 

(55100!+I%) 
65030 NEXT 1% 



Las rutinas correspondientes en có- 
digo máquina son las rutinas 5 y 6, que 
puedes ejecutar con el siguiente pro- 
grama en BASIC: 

10 CLEAR 200,55000! 

20 KEY OFF 

30 SCREEN 1 

40 FOR I%=1 T0 26 

50 READ A$ 

60 POKE 55000 !+I%, VAL 

("&H"+A$> 
70 NEXT 1% 
80 DEFUSR=55001 ! 
90 DEFUSR1=55014! 
100 FOR 1=6144 T0 6911 
110 VPOKE 1,65 
120 NEXT 
130 U=USR(0) 
140 CLS 

150 FOR 1=1 T0 100:BEEP:NEXT 
160 U=USR1(0) 

10000 DATA 21,00,18,01,00,03, 
11, 3c,d7,cd, 59,00, c9 

11000 DATA 21 ,3c,d7,01 ,00,03, 
11 ,00,18, cd,5c,00,c9 

Figura 2. — Tabla del generador de 
patrones en el modo de texto de 40 co- 
lumnas. 
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LA TABLA DEL GENERADOR DE 
PATRONES EN SCREEN 1 

Esta tabla, cuya dirección de co- 
mienzo es: 
BASE (7)=0 

es en todo similar a la correspon- 
diente tabla del modo 0, excepto, 
como ya has visto, en la dirección de 
comienzo. Ahora la dirección de co- 
mienzo del grupo i de 8 bytes corres- 
pondientes a un carácter viene dada 
por: 

código i=8*i 

Por tanto, el grupo correspondien- 
te a la letra A comienza en SCREEN 
1 en el byte: 

8*65=520 

y no en el 2568. 

Seguramente serás capaz de modifi- 
car el programa que hemos dado an- 
teriormente para disponer de dos jue- 
gos de caracteres en SCREEN 1 . 

LA TABLA DE COLOR EN EL 
MODO DE TEXTO DE 32 
COLUMNAS 

La principal diferencia entre los 
modos de pantalla 0 y 1 es que, mien- 
tras en SCREEN 0 sólo se puede de- 
finir un color para el fondo y un color 
para la tinta de todos los caracteres, 
en el modo 1 podemos definir distin- 
tos colores del fondo y de la tinta para 
cada grupo de 8 caracteres. 

Así se puede definir un color del 
fondo y un color de la tinta para los 8 
primeros caracteres, es decir los que 
tienen como códigos desde el 0 hasta 
el 7, ambos inclusive, otros colores del 
fondo y de la tinta para los caracteres 
8 al 15,... y así sucesivamente. Como 
disponemos de 256 caracteres, estos se 
dividen en 32 grupos de 8, para cada 
uno de los cuales se puede definir el 
color del fondo y de la tinta. 

Evidentemente en alguna parte de 
la memoria deberán estar almacena- 
dos estos colores. La tabla 6, que em- 
pieza en BASE(6)=8192, se ocupa de 
ello. Esta tabla tiene, por tanto, una 
longitud de 32 bytes: desde el 8192 
hasta el 8223 ambos inclusive. El byte 
8192 contiene los colores de los carac- 



teres cuyos códigos son del 0 al 7, el 
byte 8193 desde el 8 hasta el 15, etc. 
Los colores se almacenan en la misma 
forma que en SCREEN 2. El nibble 
alto contiene el color de la tinta y el 
nibble bajo el color del fondo (figura 
3). Inicialmente todos los bytes de esta 
tabla contienen el valor F4 (en hexa- 
decimal) por lo que el color de la tin- 
ta es blanco (Fh=15d) y el del fondo 
azul (4h=4d) para todos los grupos de 
caracteres. 

Además de estas tres tablas, en 
SCREEN 1 están las tablas necesarias 
para el uso de sprites. 

Para terminar hemos incluido un 
programa BASIC bastante completo 
con el que puedes explorar los carac- 
teres ASCII en los modos 0 y 1, mo- 
dificar las tablas de generadores de pa- 
trones correspondientes a los modos 0 
y 1 y modificar los colores de fondo, 
tinta y margen en ambos modos y los 
de cada juego de 8 caracteres en el 
modo 1. 

Para explorar las tablas de genera- 
dores basta pulsar 0 y 1 según el modo 
que deseemos. En los dos modos po- 
demos cambiar el carácter aumentan- 
do el código en 1, lo que se consigue 
pulsando Fl (es decir se comienza pre- 
sentando el carácter 0, después el 1, 
luego el 2,...). Si en lugar de Fl pul- 
sas F2 podrás introducir el código del 
carácter que desees ver, y si pulsas F3, 
basta con teclear el propio carácter 
(por ejemplo A). 

Para modificar un carácter puedes 
actuar de la misma forma que para ex- 
plorar la tabla. Acto seguido verás el 
cursor parpadeando sobre el carácter 
ampliado. Moviendo el cursor y pul- 
sando la barra espadadora puedes ha- 
cer que aparezca un punto de tinta 
donde no lo había o que se borre don- 
de lo había. 

Por último puedes modificar los co- 
lores de cada juego de caracteres en 
SCREEN 1 pulsando la tecla 5. Acto 
seguido te aparecerán 16 juegos de ca- 
racteres en grupos de 8. Para ver los 
16 juegos restantes pulsa la barra es- 
padadora. Al pulsar Fl el programa 
te pedirá el número indicativo del jue- 
go cuyos colores quieres modificar y 
luego los nuevos colores, ¡ojo!, en he- 
xadecimal. 




| MULE ALTO 


«MlflAJO 


1 COLMt TVTTA 


COUM FONDO 




Figura 3. — Composición de colores 
en la tabla de color en el modo de tex- 
to de 32 columnas. 

En cualquier caso puedes volver al 
menú pulsando F4. También puedes 
grabar la tabla correspondiente en cin- 
ta o en disco. Recuerda que cuando 
cambias de modo de pantalla se resta- 
blecen las tablas originales, por lo que 
debes grabar cada tabla antes de aban- 
donar el modo de pantalla correspon- 
diente. 

Si tienes alguna duda respecto a 
este programa (o respecto a cualquie- 
ra de las rutinas que incluimos) no du- 
des en escribirnos. 
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'EXPLORADOR 
MODOS 0 



DE VRAM 
Y 1 



EN 



'Juan Antonio 
Castejon 
'Versión 1 .24, 
5252 Bytes 



Feberero 



09.86 - 



CLEAR 200,55000! 
0N STOP GOSUB 2770 
STOP 0N 
P0%=4 
T0%=15 
P1%=4 
F1%=4 
SCREEN 0 
WIDTH 39 
LOCATE 3,11 

PRINT "EXPLORADOR DE VRAM 

EN MODOS 0 Y 1" 

PRINT " ";STRING$(33, 

F0R I%=1 T0 2000:NEXT 1% 
SCREEN 0 
COLOR T0%,P0% 
KEY 0FF 

PRINT "0 = Explorar el 
modo 0" 



INPUT 27 



260 


PRINT "1 = Explorar el 


520 


G0SUB 1150 






THEN 780 






modo 1 " 


530 


NP%=5 




750 


INPUT "(Nuevo color 


de 


270 


PRINT "2 = Modificar 


540 


GOTO 1650 






papel";P1% 






caracteres en modo 0" 


550 


'Modificar color modo 0 


760 


INPUT "(Nuevo color 


de 


280 


PRINT "3 = Modificar 


560 


i 






fondo"; F1% 






caracteres en modo 1" 


570 


SCREEN 0 




770 


COLOR ,P1%,F1% 




290 


PRINT "4 = Modificar 


580 


PRINT "Color actual 


de 


780 


CLS 






color en modo 0" 




papel :";P0% 




790 


KEY1, "cambio" 




300 


PRINT "5 = Modificar 


590 


PRINT "Color actual 


de 


800 


F0R I%=2 T0 10 






color en modo 1 " 




tinta:";T0% 




810 


KEY 1%,"" 




310 


PRINT: PRINT: PRINT "Pulsa 


600 


PRINT 




820 


NEXT 1% 






una opción" 


610 


INPUT "(Nuevo color 


de 


830 


KEY4,"menu" 




320 


W$=INKEY$:IF W$="" 




papel";P0% 




840 


KEY5, "grabar" 






THEN 320 


620 


INPUT "(Nuevo color 


de 


850 


KEY 0N 




330 


IF INSTR("012345",W$)=0 




tinta";T0% 




860 


0N STRIG GOSUB 1100 






THEN 320 


630 


GOTO 220 




870 


STRIG(O) 0N 





340 0N VAL(W$)+1 GOTO 350,450 

,350,450,550,640 
350 'Explorar modo 0 





;** 


RUTINA 1 ** 




D6D9 


• 

3A3BD7 


LD 


A,(55099) 


D6DC 


21C003 


LD 


HL,960 


D6DF 


ED4BF8F7 


LD 


BC,(0F7F8H) 


D6E3 


ED42 


SBC 


HL,BC 


D6E5 


C5 


PUSH 


BC 


D6E6 


E5 


PUSH 


HL 


D6E7 


C1 


POP 


BC 


D6E8 


E1 


POP 


HL 


D6E9 


CD5600 


CALL 


0056H 


D6EC 


C9 


RET 








END 









;** RUTINA 2 ** 




D6D9 


210000 


LD 


HL,0 


D6DC 


01 C003 


LD 


BC,960 


D6DF 


113CD7 


LD 


DE, 55100 


D6E2 


CD5900 


CALL 


0059H 


D6E5 


C9 


RET 








END 





360 ' 

370 S%=0 
380 GP%=2 
390 W%=39 

400 'Modificar caracteres 
modo 0 

410 ' 







;** RUTINA 5 ** 




D6D9 


210018 


LD 


HL,6144 


D6DC 


010003 


LD 


BC,768 


D6DF 


113CD7 


LD 


DE, 55100 


D6E2 


CD5900 


CALL 


0059H 


D6E5 


C9 


RET 








END 





420 GOSUB 1150 

430 NP%=0 

440 GOTO 1650 

450 'Explorar modo 1 

460 • 

470 S%=1 
480 GP%=7 
490 W%=31 

500 'Modificar caracteres 
modo 1 

510 ' 



640 'Modificar color modo 1 
650 . 

660 SCREEN 1 

670 WIDTH 31 

680 COLOR ,P1%,F1% 

690 PRINT "Color actual de 

papel:";PU 
700 PRINT "Color actual de 

fondo: ";F1% 
710 PRINT 

720 PRINT "(Deseas cambiar 
colores de papel y de 
fondo ... S/N?" 

730 W1$=INKEY$:IF W1$="" 
THEN 730 

740 IF INSTR("Ss",W1$)=0 



880 ON KEY GOSUB 2280, ,,2210, 

2400 
890 KEY(1) ON 
900 KEY(5) ON 
910 I1%=0 

920 FOR I%=I1% TO I1%+15 
930 FOR J%=0 TO 7 
940 IF I%*8+J%=127 THEN 980 
950 IF I%<4 THEN C$=CHR$(1)+ 

CHR$(I%*8+J%+64) ELSE C$= 

CHR$(I%*8+J%) 
960 LOCATE J%,I%-I1% 
970 PRINT C$ 
980 NEXT J% 
990 LOCATE 9,I%-I1% 
1000 PRINT USING"##";I% 
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1010 
1020 
1030 
1040 

1050 
1060 
1070 
1080 

1090 
1100 
1110 
1120 
1130 
1140 



LOCATE 11,I%-I1% 1290 

PRINT 8192+1% 1300 

LOCATE 17,I%-I1% 1310 

PRINT HEX$(VPEEK 1320 

(8192+1%)) 1330 

NEXT 1% 1340 

LOCATE 0,18 1350 

PRINT "(Código grupo?" 1360 

PRINT "(Color (TF) en 1370 

hexadecimal?" 1380 

GOTO 1090 1390 

'Pulsa barra espacios 1400 

i 

I1%=I1% XOR 16 1410 

CLS 1420 

RETURN 920 1430 



PRINT " " 

PRINT "Carácter:" 
KEY1,"1 a 1" 
KEY2, "código" 
KEY3, "tecla" 
KEY4,"menu" 
KEY5, "grabar" 
FOR I%=6 TO 10 
KEY 1%,"" 
NEXT 1% 
KEY ON 

ON KEY GOSUB 1970,2010, 

2100,2210,2400 

I%=BASE(GP%) 

KEYd) ON 

KEY(2) OÑ 







;** RUTINA 3 ** 


D6E6 


213CD7 


LD HL,55100 


D6E9 


01C003 


LD BC,960 


D6EC 


110000 


LD DE,0 


D6EF 


CD5C00 


CALL 005CH 


D6F2 


C9 


RET 






END 



1570 PRINT B$; 

1580 LOCATE 10 

1590 PRINT I%+J% 

1600 NEXT J% 

1610 LOCATE 9,11 

1620 IF I1%<32 THEN PRINT 

CHR$(1);CHR$(I1%+64) 

ELSE PRINT CHR$(I1%) 
1630 IF INSTR("23",W$)<>0 

THEN RETURN ELSE RETURN 

1640 
1640 GOTO 1640 
1650 'Modificar caracteres 

1660 ' 

1670 X%=1:Y%=2 

1680 ON STRIG GOSUB 1910 

1690 FOR I1%=1 TO 100:NEXT 

1700 STRIG(O) ON 

1710 LOCATE 0,12,0 







;** RUTINA 6 ** 




D6E6 


213CD7 


LD 


HL, 55100 


D6E9 


010003 


LD 


BC,768 


D6EC 


110018 


LD 


DE,6144 


D6EF 


CD5C00 


CALL 


005CH 


D6F2 


C9 


RET 








END 









;** RUTINA 4 ** 




D6D9 


3A3BD7 


i 

LD 


A, (55099) 


D6DC 


21 001 B 


LD 


HL,1B00H 


D6DF 


ED4BF8F7 


LD 


BC,(0F7F8H) 


D6E3 


ED42 


SBC 


HL,BC 


D6E5 


C5 


PUSH 


BC 


D6E6 


E5 


PUSH 


HL 


D6E7 


C1 


POP 


BC 


D6E8 


E1 


POP 


HL 


D6E9 


CD5600 


CALL 


0056H 


D6EC 


C9 


RET 








END 





1150 'Presentación 

caracteres 
1160 ' 



1170 SCREEN S% 

1180 WIDTH W% 

1190 PRINT "C"digo=" 

1200 PRINT " 

1210 PRINT ". 
1220 PRINT ". 
1230 PRINT ". 
1240 PRINT ". 
1250 PRINT ". 
1260 PRINT ". 
1270 PRINT ". 
1280 PRINT ". 



1440 
1450 
1460 
1470 
1480 
1490 
1500 
1510 

1520 
1530 
1540 



1550 
1560 



KEY(3) ON 
KEY(4) ON 
KEY(5) ON 
LOCATE 7,0 

I1%=I%§8-BASE(GP%)/8 

PRINT 11% 

FOR J%=0 TO 7 

A$=RIGHT$("00000000"+B 

$(VPEEK(I%+J%)),8) 

B$="" 

FOR K%=1 TO 8 

IF MID$(A$,K%,1)="0" 

THEN B$=B$+" " ELSE B$; 

B$+CHR$ (&HDB) 

NEXT K% 

LOCATE 1,J%+2 



1720 I3%=BASE(NP%)+Y%*(W%+1)+ 
X%+1 

1730 I4%=251 XOR VPEEK(I3%) 
1740 FOR I1%=1 TO 100:NEXT 
1750 LOCATE X%,Y%,1 
1760 C%=STICK(0) 
1770 STRIG(O) OFF 
1780 IF C%=0 THEN 1690 
1790 IF C%=1 THEN Y1%=1 
1800 IF C%=3 THEN X1%=1 

IN 1810 IF C%=5 THEN Y1%=-1 
1820 IF C%=7 THEN X1%=-1 
1830 X%=X%+X1% 
1840 Y%=Y%-Y1% 
1850 X1%=0:-Y1%=0 

= 1860 IF X%<1 THEN X%=1 
1870 IF X%>8 THEN X%=8 
1880 IF Y%<2 THEN Y%=2 
1890 IF Y%>9 THEN Y%=9 



INPUT 29 



Entorno 



ni sistemo 



1900 
1910 
1920 
1930 

1940 
1950 
1960 
1970 
1980 
1990 
2000 
2010 
2020 
2030 
2040 
2050 
2060 
2070 
2080 
2090 
2100 
2110 
2120 
2130 
2140 
2150 
2160 
2170 
2180 



2190 



GOTO 1690 

I1%=I%+Y%-2 

I2%=2 A (8-X%) 

VPOKE I1%,VPEEK(I1%) 

X0R 12% 

LOCATE 0,12,0 

VPOKE 13%, 14% 

GOTO 1690 

•key 1 



I%=I%+8 
GOTO 1420 
•key 2 



DEFUSR=&H156 

U=USR(0) 

LOCATE 11,0 

PRINT STRING$(4,127); 

INPUT 1% 

I%=I%*8+BASE(GP%) 
GOTO 1420 
•key 3 



DEFUSR=SH156 

U=USR(0) 

LOCATE 10,11 

PRINT CHR$(127); 

I$=INPUT$(1) 

I%=ASC(I$) 

IF I%<32 THEN PRINT 

CHR$(1);CHR$(I%+64) 

ELSE PRINT CHR$(I%) 

I%=I%*8+BASE(GP%) 



NO OLVIDES © 
EL TELEFONO... 

Cuando, por cualquier 
motivo, nos escribas. 



2200 
2210 
2220 
2230 
2240 
2250 
2260 
2270 
2280 
2290 
2300 
2310 
2320 
2330 
2340 
2350 
2360 
2370 
2380 

2390 
2400 
2410 
2420 
2430 

2440 

2450 

2460 

2470 

2480 
2490 
2500 
2510 
2520 
2530 
2540 
2550 
2560 



GOTO 1420 
•key 4 



FOR I%=1 TO 5 

KEY(I%) OFF 

NEXT 1% 

LOCATE,, O 

RETURN 220 

' key 1 : color 
i 

DEFUSR=&H156 

U=USR(0) 

LOCATE 17,18 

PRINT STRING$(4,127); 

INPUT C% 

LOCATE 30 

PRINT STRING$(4,127); 
INPUT C$ 

VPOKE 8192+C%,VAL 

("&h"+C$) 

RETURN 

'Grabar VRAM 



CLS 

PRINT "1 = Grabar en 
cinta." 

PRINT "2 = Grabar en 
di seo. " 

PRINT: PRINT: PRINT "Pulsa 
una opción" 
W2$=INKEY$:IF W2$="" 
THEN 2460 

IF INSTR("12",W2$)=0 
THEN 2460 

IF W$="3" THEN 2540 
IF W$="5" THEN 2580 
RESTORE 2860 
IN%=BASE(2) 
L%=2143 
GOTO 2610 
RESTORE 2870 
IN%=BASE(7) 
L%=2143 



2570 GOTO 2610 
2580 RESTORE 2880 
2590 IN%=8192 
2600 L%=31 

2610 IF W2$="2" THEN 2730 
2620 FOR I%=1 TO 13 
2630 READ W3$ 
2640 POKE 55000 !+I%, VAL 

("&H"+W3$) 
2650 NEXT 1% 
2660 DEFUSR=55001 ! 
2670 U=USR(0) 

2680 PRINT: PRINT "Pulsa REC- 
PLAY ... <RETURN>" 

2690 IF INKEY$OCHR$(13) 
THEN 2690 

2700 INPUT"(Nombre de archivo 
";W3$ 

2710 BSAVE"cas:"+W3$, 55014!, 

55014!+L% 
2720 GOTO 2750 

2730 INPUT"(Nombre de archivo 
";W3$ 

2740 BSAVE W3$,IN%,IN%+L%,S 
2750 PRINT: PRINT W3$; 

" grabado.. .<RETURN>" 
2760 IF INKEY$OCHR$(13) 

THEN 2760 ELSE 220 
2770 'stop 

2780 ' 

2790 DEFUSR=SH3E 
2800 U=USR(0) 
2810 SCREEN 0 
2820 WIDTH 39 
2830 KEY ON 
2840 LOCATE, ,0 
2850 END 

2860 DATA 21,00,08,01,00,08, 
11,E6,D6,CD,59,00,C9 

2870 DATA 21,00,00,01,00,08, 
11,E6,D6,CD,59,00,C9 

2880 DATA 21,00,20,01,20,00, 
11 ,E6,D6,CD, 59,00, C9 
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LOS OBJETOS 
DE LA AVENTURA 



DATA PARA LOS OBJETOS 



DESCRIPCIONES LARGAS Y CORTAS 



MAS VERBOS 



TOMANDO Y DEJANDO OBJETOS 



RUTINA DE INVENTARIO 



Ha llegado el momento de llenar tu 
vacío mundo de aventura con objetos. 
Te enseñaremos cómo puedes incorpo- 
rar en el programa tu lista de objetos 
y la forma de manejarlos. 

Al final del capítulo anterior tenía- 
mos un conjunto completo de ambien- 
tes para la aventura y ya habíamos 
proporcionado al aventurero la capa- 
cidad de moverse por todo el mundo 
de la aventura. Sin embargo en la fase 
actual las actividades del aventurero 
todavía carecen de sentido, ya que aún 
no sucede nada en ninguno de los lu- 
gares. Ha llegado el momento de vol- 
ver atrás y ver lo que habías planeado 
incluir en cada punto. 

Vamos a ver a continuación, la for- 
ma de agregar las rutinas necesarias 
para llegar al sitio adecuado y recoger 
o abandonar todos los objetos que in- 
tervienen en la aventura. También 
presentaremos una rutina que hace un 
inventario de todos los objetos que el 
aventurero lleva consigo en un mo- 
mento dado, la cual puede resultar útil 
en los momentos más críticos de la ac- 
ción. 

Carga el programa que tienes des- 
de el capítulo anterior y prepárate a 
introducir nuevas rutinas. 




OBJETOS 

La máquina necesita saber tres co- 
sas acerca de los objetos de una aven- 
tura: el número del lugar donde el ob- 
jeto estaba inicialmente situado, listo 
para que el aventurero lo encontrara, 
un nombre para el objeto y una des- 
cripción más larga que incluirá algo 
acerca de la situación del objeto y su- 
gerirá de alguna forma su empleo. Es- 
tas tres cosas son indispensables para 
el ordenador, ya que en primer lugar 
tiene que saber si un determinado ob- 
jeto está o no en un ambiente, además 




tiene que poder avisar al jugador de 
su presencia, con ayuda de la descrip- 
ción larga y, por último, necesita un 
nombre corto, para utilizarlo en ins- 
trucciones e inventarios. 

Los números de los lugares se situa- 
rán en una matriz, el título de los ob- 
jetos en otra y las descripciones de los 
objetos en una tercera. El programa 
procesará las tres matrices en parale- 
lo; cada elemento de la matriz sopor- 
ta una información acerca de los ob- 
jetos, el primero es el número del lu- 
gar, el segundo es el nombre, etc. 

Añade a tu programa las siguientes 
líneas: 

160 REM ** MATRICES OBJETOS 
170 READ NB 

180 DIM 0B(NB),0B$(NB), 

SISCNB) 
190 FOR 1=1 T0 NB:READ 

0B(I), 0B$(I),SI$(I) 

NEXT 

200 DATA 7,4, BOLSA, HAY UN 

BOLSA DE CANICAS 
210 DATA 14, LADRILLO, HAY UN 

LADRILLO A TUS PIES 
220 DATA 24, CADENA, UNA CADENA! 

CUELGA DEL TECHO 
230 DATA 0, PISTOLA, HAY UNA 

PISTOLA EN EL SUELO 
240 DATA 0, GLOBO OCULAR, EN EL 

SUELO HAY UNA ALHAJA CON 

FORMA DE OJO 
250 DATA 22, LAMPARA, VES UNA 

LAMPARA 

260 DATA 0, INSPECTOR FISCAL, 
UN INSPECTOR FISCAL 
APARECE DE REPENTE 

Cada línea desde la 200 a la 260 con- 
tiene tres elementos de los DATA re- 
feridos al mismo objeto. La línea 200 
incluye un elemento suplementario: el 
número 7 al principio de los datos in- 
forma a la máquina de cuantos con- 
juntos de datos hay. 

Una vez que se lee el número 7 en 
la línea 170, se dimensionan tres ma- 
trices con ese tamaño en la línea 180. 
OB contendrá la situación de cada ob- 
jeto, ya sea un número de lugar, un 0 
si el objeto todavía no existe (por 
ejemplo el famoso ojo de brillantes 
que tiene que ser descubierto durante 
la aventura), o un -1 si se trata de un 



objeto que el aventurero lleva consi- 
go. OB$ contendrá las descripciones 
cortas y SI$ las descripciones largas. 

La línea 190 llena las matrices con 
datos de las líneas 200 a 260. Los da- 
tos se disponen en grupos de tres de 
la forma siguiente: número de lugar, 



descripción corta del objeto y descrip- 
ción larga del mismo. 

Cuando uses esta rutina para otras 
aventuras, no tendrás que hacer mu- 
chas modificaciones en su estructura, 
ya que al ajustar el primer elemento 
de los DATA, automáticamente se di- 
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me Fisionarán tanto el bucle FOR ... 
NEXT como las matrices. 

DISPOSICION DE LOS OBJETOS 

A continuación el programa contie- 
ne toda la información referente a la 



naturaleza y colocación de los objetos. 
La siguiente rutina presenta la des- 
cripción larga del objeto en el lugar 
adecuado: 

360 REM ★* VISUALIZACION DE 
OBJETOS EN EL LUGAR 




APROPIADO 
370 FOR 1=1 T0 NB:IF 

0B(I)=L THEN PRINT 

SI$(I) 
380 NEXT I 

En esta fase tienes que hacer una 
pequeña modificación en las líneas 330 
y 340: cambia el GOTO 400 por 
GOTO 370. Las líneas 370 y 380 exa- 
minan la matriz que contiene los luga- 
res de los objetos. Si alguno de los nú- 
meros de los lugares coincide con el 
del lugar donde se encuentra el obje- 
to en ese momento — variable L — 
aparece la descripción larga del obje- 
to a continuación de la del lugar. Esta 
rutina se puede usar sin modificacio- 
nes en otras aventuras. 

MAS VERBOS 

Ya tienes en tu aventura unos cuan- 
tos objetos esparcidos por los diversos 
lugares, pero como la máquina toda- 
vía no entiende más palabras que 
NORTE, SUR, ESTE y OESTE, el 
pobre aventurero no puede hacer 
nada con esos objetos. Imagínate la 
frustración de no poder coger esa ape- 
titosa bolsa de canicas o no poder de- 
fenderte contra el inspector de hacien- 
da. Por eso tienes que darle al orde- 
nador un vocabulario de palabras que 
pueda reconocer, diciéndole qué debe 
hacer con los objetos. Más adelante 
veremos qué hacer si el jugador intro- 
duce una palabra que no esté en el vo- 
cabulario suministrado a la máquina. 

Ya que el programa trata todas las 
palabras de las direcciones como ver- 
bos, el mejor sitio para los verbos que 
indican lo que hacer con los objetos 
será la matriz R$, y el mejor sitio para 
los correspondientes números será la 
variable R. 

En consecuencia tendrás que hacer 
algunas modificaciones, empezando 
por la línea 130. Tienes que cambiar 
los límites del bucle FOR ... NEXT. 
La nueva versión de dicha línea es: 

130 FOR K=1 T0 19:READ R$(K) 
,R(K) :NEXT 

Seguidamente, añade las líneas 140 
y 145: 
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140 DATA NAD0,5,VACI0,6,LUZ,7 
, FIN, 8, LISTA, 9, MATO, 10, 
DISPARO, 10, AYUDA, 11 

145 DATA COJO, 2 , RECOJO, 2 , 
LLEV0,2,P0NG0,3,DEJ0,3, 
ABANDONO, 3, TIRO, 4 

Cada verbo tiene su correspondien- 
te número. Verbos con el mismo nú- 
mero tienen el mismo significado, por 
lo que al ordenador se refiere, y rea- 
lizarán la misma operación. Por ejem- 
plo, programando las cosas para que 
el ordenador acepte COGER, TO- 
MAR y LLEVAR, el aventurero se 
ahorrará mucho de gasto de tiempo in- 
necesario intentando descubrir cuál de 
estas palabras tiene que usar. Puedes 
añadir con facilidad tus propias pala- 
bras en las líneas de DATA cambian- 
do el bucle FOR ... NEXT de la línea 
130 y poniendo los nuevos DATA al 
final de la línea 145. Tienes que hacer 
más modificaciones en otras partes del 
programa, pero ya te diremos más 
adelante lo que tienes que hacer. 



OTRAS RUTINAS 



Después de que has completado la 
lista de verbos con la última rutina, el 
ordenador necesita algunas rutinas 
que le permitan atender instrucciones 
tales como hacer que el aventurero lle- 
ve determinados objetos. 

La subrutina que comienza en la lí- 
nea 3010 define V$, N$ e I, que es un 
número extraído de la matriz R. Con 
esta corta rutina, la máquina podrá 
comprender el significado de cada res- 
puesta del aventurero, según el valor 
de I. 

500 REM ** ENCONTRAR OPCION 

505 IF 1=0 THEN GOTO 520 

510 0N I GOTO 1010,1150,1240, 

1310,1410,1460,1500,1360, 

1080,1550,3110 
520 PRINT:PRINT"N0 CONOZCO... 

";V$:G0T0 370 

Cada uno de los números que figu- 
ran después de la sentencia ON ... 
GOTO en la línea 510 es el principio 
de una subrutina. Cada valor de I co- 
rresponde a un verbo o grupo de ver- 



bos diferente. Por ejemplo, si I = 10, 
se seleccionará la rutina «matar», es el 
décimo número de la línea, por lo que 
la rutina comienza en la línea 1550. 

Si la subrutina de comprobación de 
instrucciones, que comienza en la lí- 
nea 3010, no encuentra coincidencias 
para la parte V$ de R$, se asigna a I 
el valor 0. En tal caso no tendrá efec- 
to la sentencia ON ... GOTO de la lí- 
nea 510 y se presentará el mensaje de 
la línea 520. 



LA TOMA DE OBJETOS 



Ya tienes la rutina para el 1 = 1 , co- 
rrespondiente al caso en que el aven- 
turero introduce una palabra de direc- 
ción; dicha rutina se encuentra en las 
líneas 1010 a 1060. 

Cuando 1 = 2, significa que el aven- 
turero ha tecleado una palabra de «co- 
ger», como COGER, TOMAR o 
LLEVAR. La siguiente rutina permi- 
tirá al aventurero llevarse consigo 
cualquier objeto que haya en el lugar 
en que se encuentra. Sería algo así: 

1140 REM ** RUTINA COJO 

1150 FOR G=1 T0 NB 

1160 IF N$=LEFT$(0B$(G), 

LEN(N$) ) THEN 1190 
1170 NEXT 

1180 PRINT:PRINT"N0 COMPRENDO 

...";N$:G0T0 330 
1190 IF 0B(G)=-1 THEN PRINT: 

PRINT"YA LO TIENES": 

GOTO 330 
1200 IF 0B(G)OL THEN PRINT: 

PRINT'NO ESTA AQUI": 

GOTO 330 
1210 PRINT"0K":0B(G)=-1 
1220 GOTO 330 

En las líneas 1150 a 1170 se busca 
la matriz OB$ que contiene las des- 
cripciones cortas de objetos, para sa- 
ber qué objeto es el designado por el 
aventurero. Si se encuentra el nombre 
del objeto, el programa salta a la lí- 
nea 1190. Si el objeto no figura por 
ninguna parte de la aventura, la línea 
1180 presenta el mensaje NO EN- 
TIENDO, seguido del nombre de ob- 
jeto tecleado por el aventurero. 

Suponiendo que el objeto designa- 



do haya sido encontrado, hay que 
comprobar dos cosas. La línea 1190 
examina el elemento de la matriz OB 
correspondiente a dicho objeto, para 
ver si ya está en poder del jugador. Si 
el jugador ya lo tiene (el correspon- 
diente valor de la matriz es - 1) se pre- 
sentará el mensaje YA LO HAS CO- 
GIDO. 

En la línea 1200 se comprueba si el 
objeto está presente, examinando 
nuevamente la matriz de lugares. Si no 
está presente, el programa dice: NO 
ESTA AQUI. Naturalmente, puedes 
cambiar estos mensajes por otros, si 
no se adaptan bien a tu aventura. 

Si el objeto está en el mismo lugar 
que el aventurero y no ha sido cogido 
por éste, la línea 1210 dice OK y en el 
correspondiente elemento de la matriz 
de lugares se pone el valor - 1 . 



ABANDONO DE OBJETOS 



La rutina de «abandono» hace exac- 
tamente lo contrario que la anterior. 
Permite al aventurero dejar los obje- 
tos que no quiere llevar con él. 

1230 REM RUTINA DEJO 

1240 FOR G=1 T0 NB 

1250 IF N$=LEFT$(0B$(G), 

LEN(N$) ) THEN 1270 
1260 NEXT: PRINT: PRINT n N0 

COMPRENDO... ";N$:G0T0 

330 

1270 IF 0B(G)<>-1 THEN PRINT 
PR INT M N0 LO LLEVAS": 
GOTO 330 

1280 PRINT"0K M :0B(G)=L 

1290 GOTO 330 

Esta rutina funciona de una forma 
muy parecida a la de «toma». Nueva- 
mente se examina la matriz de descrip- 
ciones cortas, esta vez se hace en las 
líneas 1240 a 1260. Si el objeto desig- 
nado por el aventurero figura en la 
matriz, la línea 1270 comprueba si el 
aventurero lo lleva o no. Si no lo lle- 
va, se presenta el mensaje NO LO 
LLEVAS. 

Si el aventurero lleva el objeto, la lí- 
nea 1280 envía el mensaje OK y se 
ajusta el correspondiente elemento en 
la matriz de situación de objetos OB. 
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P y R 

¿Se puede utilizar un sintetiza- 
dor de voz con una aventura? 

Tu aventura podría resultar 
más interesante programando la 
máquina de modo que anuncie 
acústicamente los mensajes, di- 
recciones y descripciones de ob- 
jetos, en lugar de representarlos 
en la pantalla. 

Consulta el manual de tu sin- 
tetizador para ver cómo se pue- 
de hacer que la máquina hable 
y sustituya a las instrucciones 
que contienen las sentencias 
PRINT. 



Ahora tiene el mismo valor que el lu- 
gar actual, es decir L, en vez de -1 
que significaba que lo llevaba el aven- 
turero. 



LA LISTA DEL BOTIN 



Los aventureros desmemoriados es- 
tarán muy contentos de poder contar 
siempre que quieran con una lista de 
todos los objetos que llevan. Aquí tie- 
nes una rutina que hará exactamente 
eso: 

1070 REM *★ LISTA 

1080 PRINT: PRINT"TI ENES : "; 

:IN=0 
1090 F0R G=1 T0 NB 
1100 IF 0B(G)=-1 THEN PRINT 

TAB(10)0B$(G) :IN=IN+1 
1110 NEXT 

1120 IF IN=0 THEN PRINT 

TABdO) "NADA" 
1130 GOTO 330 

La línea 1080 envía el mensaje 
LLEVAS, seguido de la lista de obje- 
tos. El bucle FOR...NEXT comprue- 
ba todos los elementos de la matriz de 
situación de objetos. Esta vez los ele- 
mentos importantes son los que tienen 
el valor - 1 , significando que el corres- 
pondiente objeto es uno de los que lle- 
va el aventurero. Si el valor de un ele- 
mento es -1, se presenta la descrip- 
ción corta del objeto en cuestión, to- 
mándola de la matriz. El contador de 
inventario IN se incrementa en L 

Si el aventurero no lleva ningún ob- 
jeto, IN se queda a cero y la línea 1120 
en vez de la lista de objetos presenta 
el mensaje NADA. 

Las rutinas de «toma», «abandono» 
e «inventario» pueden utilizarse tal 
como están , ya que NB ha sido defi- 
nido en una rutina anterior. 

Almacena ahora el programa 
(SAVE), dejándolo dispuesto para re- 
cibir las rutinas finales que veremos la 
próxima vez. Se trata de las rutinas co- 
rrespondientes al inspector de hacien- 
da, el ladrillo, la lámpara, el encuen- 
tro de la joya, el final de la aventura 
y, finalmente, la instrucción que des- 
cribe el objeto de la búsqueda. 

Si ejecutas el programa ahora, ve- 
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rás que hay partes del mismo que fun- 
cionan mientras que en otras partes 
ocurren cosas extrañas. La razón es 
que todavía hacen falta unas cuantas 
rutinas y el programa salta a líneas que 
aún no existen. 



ELIMINANDO FALLOS 

- Asegúrate de que los tres grupos 
DATA que contienen datos relaciona- 
dos con los objetos se leen en la ma- 
triz adecuada. Si intentas meter datos 
de cadenas de caracteres en una ma- 
triz numérica, recibirás un mensaje de 



error, o puede que te encuentres con 
una descripción corta cuando espera- 
bas una larga. 

- Ten mucho cuidado en respetar el 
orden de los DATA en corresponden- 
cia con el orden de lectura de las ma- 
trices. El orden correcto es: lugar, 
nombre o descripción corta, descrip- 
ción larga. 

- Después de introducir los objetos 
haz una pasada de prueba del progra- 
ma, para asegurarte de que los obje- 
tos aparecen en el sitio correcto. 

- Al comprobar los objetos, hazlo 
sobre la retícula, para asegurarte de 
que no se te ha olvidado nada. 




COMPLETANDO 
LA AVENTURA 



UNA RUTINA DE AY UDA 
EL INSPECTOR DE HACIENDA 



PROBLEMAS CON EL LADRILLO 



ENCENDIENDO LA LAMPARA 



INSTRUCCIONES 



La aventura de INPUT está ya casi 
completa. Sólo quedan las rutinas que 
la convierten en una aventura única, 
las rutinas especiales que confieren a 
este juego su carácter. 



Ya has completado casi todos los 
elementos que integran tu juego; es el 
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momento de incorporar los últimos 
detalles del programa. Tienes que 
añadir aún algunas cosas, como los pe- 
ligros, las advertencias, y tienes que 
prever un camino de salida para el 
caso de que la aventura se complete 
con éxito. Por último, tienes que po- 
ner las instrucciones para jugar. 

Dado que muchas de estas rutinas 
están escritas de forma que contienen 
detalles específicos de una aventura 
particular, en los programas que si- 
guen completaremos el juego y te 
mostraremos en términos generales 
todo lo que se relaciona con esta fase 
del programa. En otras aventuras no 
podrás utilizar estas rutinas sin modi- 
ficarlas. En el próximo capítulo vere- 
mos la forma en que puedes adaptar 
estos principios para aplicarlos a tus 
ideas originales. 



NECESITAS AYUDA 

Si el juego de aventuras que has es- 
crito es bueno, lo más probable es que 
el aventurero necesite alguna ayuda. 
Deberás pues prever unas cuantas su- 
gerencias útiles. 

Estas sugerencias tendrán la forma 
de mensajes que el ordenador enviará 
mediante sentencias PRINT en res- 
puesta a las solicitudes de AYUDA 
hechas por el jugador. Lo que digan 
los mensajes y los puntos en que pue- 
dan estar disponibles, queda a tu en- 
tera discreción, ya que tú eres quien 
programa la aventura. Si quieres, pue- 
des hacer que no haya un solo mensa- 
je, o hacer que sean deliberadamente 
engañosos, o bien proporcionar ayuda 
únicamente en unas cuantas situacio- 
nes aisladas. El primer paso para de- 
cidir lo que incluir es volver a consi- 
derar tu plan original sobre las líneas 
maestras de la aventura. 

En la aventura, hay varios puntos 
en los que convendría enviar al juga- 



dor un corto mensaje. Por ejemplo, 
podrías advertirle acerca de la habita- 
ción oscura, de forma que cuando esté 
en un lugar contiguo a dicha habita- 
ción, la respuesta ante su posible soli- 
citud de ayuda podría ser un mensaje 
como: MIRA ANTES DE DAR EL 
SALTO, o incluso algo más críptico. 

Otro sitio donde se podría incluir un 
mensaje de aviso es la orilla del río, 
donde, en el caso de que se decida a 
nadar, el aventurero corre el riesgo de 
ahogarse dependiendo de que lleve o 
no el ladrillo. 

Naturalmente, puedes repasar una 
a una todas las situaciones en las que 
podría ser conveniente un poco de 
ayuda, pero supongamos que decides 
no ayudar demasiado y enviar un men- 
saje en un solo punto, el río. Tienes 
que hacer referencia a este número de 
lugar, el número 7, y a la variable que 
registra la presencia del ladrillo, 
OB(2): 

3100 REM *★ RUTINA AYUDA 
3110 IF L<>7 0R 0B(2)<>-1 
THEN PRINT:PRINT"L0 
SIENTO, NO TE PUEDO 
AYUDAR AQUI!":G0T0 330 
3120 PRINT: PRINT M L0S 

LADRILLOS PESAN MUCHO Y 
HACEN QUE TE DUELA EL 
BRAZO" : GOTO 330 

Si el aventurero no está en la orilla 
(L<>7), o no lleva consigo el ladrillo 
(OB(2)<> -1), la línea 3110 presen- 
tará el mensaje LO SIENTO, NO TE 
PUEDO AYUDAR AQUI. Si al lle- 
gar a la orilla del río, el aventurero lle- 
va el ladrillo y pide ayuda, la línea 
3120 imprimirá el siguienten mensaje 
de advertencia: LOS LADRILLOS 
PESAN MUCHO Y HACEN QUE 
TE DUELA EL BRAZO. 

Caso de que quieras hacerlo, no hay 
nada que te impida incluir una lista 
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completa de condiciones con sus co- 
rrespondientes mensajes de aviso. 



EL INSPECTOR DE HACIENDA 



En la aventura interviene un sujeto 
que está por ahí merodeando, que es 
un inspector de hacienda el cual inten- 
ta recuperar parte de los impuestos 
impagados por el aventurero, confis- 
cándole uno de los objetos que lleva. 
No se preocupa mucho de cuáles son 
esos objetos, por lo que en algunos ca- 
sos incluso podría aceptar como pago 
un ladrillo. 

Si el aventurero no tiene la suerte 
de llevar nada consigo en el momento 
en que se encuentra con el inspector 
de hacienda, será encerrado en una 
mazmorra en la que se pudrirá para 
siempre. Y aquí termina el juego. 

El papel del inspector de hacienda 
es proporcionar al juego un elemento 
probabilístico, que resulte impredeci- 
ble independientemente de cómo se 
encuentren las demás condiciones. 
Como en otros ejemplos de introduc- 
ción de probabilidades en la progra- 
mación, puedes hacerlo recurriendo a 
la función RND. Por lo demás, pue- 
des tratarlo como otro objeto cual- 
quiera; la única diferencia es que su si- 
tuación no es fija, sino que se estable- 
ce de forma aleatoria. 

Aquí tienes las líneas suplementa- 
rias que añadir para que aparezca el 
inspector fiscal: 

320 R=RND(-TIME):IF INT 

(RND(1)*15+1)=1 AND TA=0 
THEN 0B(7)=L:TA=1 

480 IF 0B(7)=L AND IO10 
THEN 1590 

La línea 320 hace que el aventurero 
tenga una probabilidad sobre 15 de 
encontrarse con el inspector. Sólo se 
le permite aparecer una vez durante el 
juego, por lo que necesitas una varia- 
ble, TA, para indicar si ha aparecido 
o no. 

Si el número aleatorio es 1 o menor 
que 1/15, y el inspector todavía no ha 
aparecido, la línea 320 ajusta el valor 
que corresponde al inspector de ha- 
cienda en la matriz de situación de ob- 



jetos. La presentación del mensaje del 
inspector se hace igual que si se trata- 
se de un objeto, almacenándose en la 
descripción larga de la matriz. 

La línea 480 tiene que ver con la su- 
presión del inspector. Se limita a com- 
probar si has intentado matarle. Si no 
lo has intentado, el programa salta a 
la línea 1590. 



LA RESPUESTA ANTE EL 
IMPUESTO 



Cuando el inspector vuelve su fea 
cabeza, sólo hay una solución posible. 
El aventurero debe disparar contra él 
utilizando la pistola que se encontró 
en el río: 

1540 REM RUTINA DISPARO 
1550 IF 0B(4)<>-1 THEN PRINT' 

CON QUE?":G0T0 320 
1560 IF 0B(7)OL THEN PRINT 

V$;" A QUIEN? M :G0T0 320 
1570 PRINT: PRINT"M ATAS TE AL 1 

;0B$(7) :OB(7)=0: 

GOTO 330 

Esta rutina se utiliza cuando el 
aventurero escribe las palabras 
MATO o DISPARO. Si no lleva la 
pistola (OB(4) <> -1), la línea 1550 
presentará el mensaje CON QUE? 
Análogamente si el inspector de ha- 
cienda no está presente y el jugador 
intenta matarle, la línea 1560 le pre- 
gunta A QUIEN? 

La línea 1570 le dice al aventurero 
MATASTE AL INSPECTOR DE 
IMPUESTOS, y ajusta la matriz de si- 
tuaciones de los objetos de forma que 
dicho inspector ya no existe. 



LA VENGANZA DEL INSPECTOR 



El aventurero se encuentra con lo 
siguiente: 

1580 REM ** INSPECTOR FISCAL 
1590 IN=0:0B(7)=0 
1600 FOR K=1 T0 NB 
1610 IF 0B(K)=-1 THEN 

IN=IN+1 
1620 NEXT 



1630 IF INO0 THEN 1640 
1635 PRINT:PRINT"C0M0 NO 

LLEVAS NADA TE 

ENCIERRA " 
1638 PRINT"EN UNA FRIA 

MAZMORRA" : GOTO 1360 
1640 R=RND(-TIME) :K=INT 

(RND(1)*NB+1) :IF 0B(K) 

<>-1 THEN 1640 
1650 PRINT "EL INSPECTOR TE 

CONFISCA EL OBJETO ";0B$ 

(K) :0B(K)=0:G0T0 330 

Al inspector sólo se le permite apa- 
recer una vez durante toda la aventu- 
ra, por lo que la línea 1590 ajusta la 
matriz de situación de objetos ponien- 
do a cero el que corresponde al ins- 
pector; OB(7). Esto no tiene efecto al- 
guno en esta rutina, pero hace que una 
vez que salgamos de ella, el inspectqr 
no vuelva a aparecer. IN es un conta- 
dor utilizado para comprobar si se lle- 
van objetos. 

En las líneas 1600 a 1620 se recorre 
toda la matriz de situaciones de obje- 
tos, para comprobar si cada uno de los 
objetos se lleva o no. Por cada objeto 
que se porte, se incrementa IN en 
uno. 

Si el aventurero no lleva objeto al- 
guno, el valor de IN permanece a cero 
y se presenta el siguiente mensaje: 
COMO NO LLEVAS NADA, TE 
ENCIERRA EN UNA FRIA MAZ- 
MORRA. El juego termina aquí, y se 
pregunta de nuevo al aventurero si 
quiere jugar otra vez saltando a la lí- 
nea 1360. 

Si por el contrario el aventurero lle- 
va objetos consigo, en la línea 1640 se 
elige uno al azar. Si el número elegi- 
do corresponde a uno de los objetos 
transportados por el aventurero, dicho 
objeto es confiscado; si por el contra- 
rio dicho objeto no ha sido cogido, se 
selecciona otro número al azar, si- 
guiendo así hasta que el número ele- 
gido corresponda a uno de los objetos 
transportados. 

Después de que ha sido selecciona- 
do un objeto, la línea 1650 informa al 
aventurero de que dicho objeto ha 
sido confiscado por el inspector. La 
matriz de situación de objetos queda 
modificada de forma que dicho obje- 
to ya no existe. 



56 INPUT Juegos 



FRevista 



de Hardware 



LAS NUEVAS UNIDADES DE DISCO 
Y LA COMPATIBILIDAD 




Las nuevas unidades de disco que in- 
corporan casi todos los equipos de la 
segunda generación MSX2 tienen una 
capacidad doble (720K) y graban en un 
formato diferente (doble cara) al de las 
primeras unidades de disco MSX. 
¿Hasta que punto son compatibles es- 
tos dos diferentes estándares? 



La diferencia fundamental entre es- 
tos dos tipos de unidad de discos está 
en que la grabación de información se 
lleva a cabo, en el caso de las unida- 
des de simple cara, a través de un sólo 
cabezal de lectura/escritura, mientras 
que en las nuevas unidades se utilizan 
dos cabezales, uno para cada cara del 
diskette. De esta forma, las nuevas 
unidades son capaces de almacenar, 
en el mismo diskette, una cantidad do- 
ble de información (720 Kbytes frente 
a los 360 Kbytes de las unidades de 
simple cara). 

Estas unidades no son exclusivas de 
los equipos de la segunda generación. 
Por ejemplo Mitsubishi comercializa 
la unidad ML-03FD, de doble cara, 
que pueden utilizarla tanto equipos de 
la primera como de la segunda gene- 
ración. 

Otro caso es el del equipo SVI 738 
X'press, de Spectravideo, que siendo 
de la primera generación (aunque con 
características fuera de lo común) in- 
cluye unidades de doble cara. 

Otro caso lo forman algunos equi- 
pos segunda generación como los pri- 
meros Philips VG-8235, en los que la 
unidad incorporada es de simple cara. 

Para contemplar el panorama cite- 
mos los casos del Sony HB-F500P, del 
Mitsubishi ML-G3 y de los nuevos 
Philips NMS 8250 y NMS 8280. En to- 
dos ellos, y esta es la línea que segui- 
rán probablemente todos los nuevos 
modelos MSX, la unidad de discos in- 
corporada es de doble cara. 

Con esta variedad de configuracio- 



nes lo primero que uno se pregunta es: 
¿Qué pasa con la compatibilidad? 



COMPATIBILIDAD ASCENDENTE 



Al margen de que las nuevas unida- 
des de disco graben en las dos caras 
del diskette, el resto de las caracterís- 
ticas y de los formatos de grabación 
empleados son exactamente los mis- 
mos que los de las antiguas unidades 
de simple cara. En ambos casos, una 
cara del diskette queda formateada en 
80 pistas de 9 sectores cada una y con 
capacidad para almacenar hasta 512 
bytes en cada sector. Esta identidad 
de formatos y el hecho de que las uni- 
dades de doble cara comiencen a gra- 
bar información por la cara 1 y sólo 
pasen a la cara 2 cuando se han llena- 
do los 360 Kbytes de la primera cara, 
garantiza la compatibilidad, siempre 
que la entendamos como compatibili- 
dad ascendente. 

El mes pasado, al hablar del nuevo 
equipo ML-G3 de Mitsubishi, comen- 
tábamos que la unidad de diskettes in- 
corporada, de doble cara, tenía un for- 
mato de grabación no compatible con 
el de las unidades de la primera gene- 



ración (de simple cara) y que en cier- 
tos casos iba a resultar necesaria una 
conversión de formatos. Esto va a ser 
cierto siempre que intentemos traba- 
jar con los programas grabados en la 
cara 2 del diskette, utilizando una uni- 
dad de simple cara. Es físicamente im- 
posible leer la información almacena- 
da en la cara 2 si sólo tenemos un ca- 
bezal de lectura/escritura que trabaja 
en la cara 1. 

Pero si hablamos de compatibili- 
dad, hay que entenderla como compa- 
tibilidad ascendente, considerando 
que dos equipos son compatibles si los 
programas del equipo de menores 
prestaciones pueden funcionar sin 
problemas en el equipo de mayores 
prestaciones. En este caso hay que 
matizar y decir que la unidad de do- 
ble cara del ML-G3, y las del resto de 
los equipos MSX2, son perfectamente 
compatibles con las unidades de sim- 
ple cara. Esto quiere decir que cual- 
quier diskette grabado en una unidad 
de simple cara, podrá ser leído perfec- 
tamente por la unidad de doble cara. 
Los usuarios que asciendan desde una 
unidad de simple a otra de doble cara, 
podrán utilizar todo el software que 
tengan en diskette. 
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EL MAESTRO 
ZEN 



ZEN es el nombre de un paquete en- 
samblador, desensamblador, monitor 
producido para MSX por Avalon Soft- 
ware y disponible en dos versiones: 
cassette y diskette (en este último caso 
bajo el sistema operativo MSX-DOS. 

Aunque no es el programa más so- 
fisticado para analizar o generar pro- 
gramas en ensamblador Z80, destaca 
por su sencillez de manejo y por per- 
mitir la creación de ficheros «.COM» 
(esto es, ficheros ejecutables que se 
incorporan al sistema operativo como 
nuevos comandos) cuando se trabaja 
desde MSX-DOS. 

Una vez terminada la carga en me- 
moria sabremos que estamos bajo el 
control del mismo cuando nos aparez- 
ca en sustitución del antiguo cursor 
«>» otro indicador compuesto por la 
palabra «ZEN>». A partir de este 
momento el programa espera que le 
ordenemos ejecutar cualquier coman- 
do. 

El ZEN, para hacernos una idea, no 
es más que un pequeño editor de tex- 
to que dialoga con nosotros mediante 
unos determinados comandos. Si no 
entiende alguno de los que le introdu- 
cimos nos responderá con el mensaje 
de error «HUH?». Si en vez de orde- 
narle algo presionamos la tecla de RE- 
TURN, se borrará la pantalla y el cur- 
sor se situará en la línea superior. 

LOS COMANDOS 



Para comunicarnos con el programa 
disponemos de 26 comandos. Estos 
son introducidos por la primera letra 
de su nombre, en inglés y en mayús- 
culas, seguido de un parámetro si fue- 
se necesario. 

La lista de comandos es la siguiente: 

1.- A (Assemble) 

Ensambla el programa fuente resi- 
dente en memoria. 




2. - B (Bye) 

Se utiliza para salir del programa. 

3. - C (Copy) 

Sirve para mover un bloque de me- 
moria. 

4. - D (Down) 

Desplaza el puntero del programa a 
la línea anterior. 

5. - E (Enter) 

Permite insertar líneas de programa 
en la posición que está señalada por el 
cursor. 

6. - F (Fill) 

Rellena una zona de memoria con 
el valor que queramos. 



7. - G (Goto) 

Ejecuta una rutina situada en me- 
moria. 

8. - H (Howbib) 

Indica el comienzo y el final del pro- 
grama fuente en memoria. 

9. - I (In) 

Informa sobre el estado de un port 
determinado. 

10. - K (Kill) 

Elimina el programa fuente de la 
memoria. 

11. - L (Lócate) 

Permite buscar una cadena. 

12. - M (Modify) 
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Posibilita la modificación del conte- 
nido de la memoria. 

13. - N (New) 

Edita para su modificación la línea 
apuntada por el cursor. 

14. - O (Out) 

Envía un dato por el port especifica- 
do. 

15. - P (Print) 

Lista n líneas desde la señalada por 
el cursor. 

16. - Q (Query) 

Presenta en pantalla 64 bytes en for- 
mato hexadecimal y ASCII. 

17. - R (Read) 



RS lee programa fuente. 
RB lee programa objeto (ver. cas- 
sette). 

RC lee programa objeto (ver. 
MSX-DOS). 

18. - S (Sort) 

Visualiza en pantalla las etiquetas 
utilizadas durante el ensamblado. 

19. - T (Target) 

Posiciona el cursor en una línea de- 
terminada. 

20. - U (Up) 

Desplaza el puntero del programa a 
la línea siguiente. 

21. - V (Verify) 



VS verifica programa fuente (ver. 
cassette). 

VB verifica programa objeto (ver. 
cassette). 

V visualiza directorio (ver. MSX- 
DOS). 

22:- W (Write) 

WS salva programa fuente. 

WB salva programa objeto (ver. 
cassette). 

WC salva programa objeto (ver. 
MSX-DOS). 

23. - X (Xamine) 

Muestra el contenido de todos los 
registros del Z80. 

24. - Z (Zap) 

Elimina n líneas desde la apuntada 
por el cursor. 

25. - d (disassemble) 
Desensambla un bloque de memo- 
ria. 

26. - u (unscramble) 
Desensambla una zona de memoria 

para que podamos dar un «vistazo rá- 
pido a su contenido. 

ESCRIBIENDO PROGRAMAS 
FUENTE 



El programa ZEN genera los pro- 
gramas fuente creando un pequeño fi- 
chero ASCII residente en memoria 
con ayuda de un editor de líneas. Es- 
tos programas fuente también pueden 
ser generados desde el MSX-DOS me- 
diante la instrucción COPY CON 
NOMBRE. SRC o con cualquier otro 
editor de líneas que trabaje con for- 
mato ASCII, siempre que le añada- 
mos la extensión .SRC. 

El formato de cada sentencia escri- 
ta en ensamblador debe ser el siguien- 
te: 

ETIQUETA: CODIGO OPE- 
RANDOS; COMENTARIOS 

Además de los códigos normales del 
Z80 el ZEN añade otras pseudo-ope- 
raciones: DEFB o DB, DEFW o DW, 
DEFS o DS, END, LOAD y ORG. 
El uso de END es obligatorio al final 
de cada programa para indicarle al en- 
samblador donde termina su trabajo. 
También es importante no olvidarse 
de las instrucciones ORG xxxx para 
que el código objeto quede organiza- 
do en una dirección determianda y 
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LOAD xxxx para que el resultado de 
la compilación sea cargado en la direc- 
ción xxxx (las direcciones de ORG y 
LOAD no tienen por que coincidir). 

Como el movimiento se demuestra 
andando vamos a trabajar con un 
ejemplo. Supongamos que tenemos la 
versión MSX-DOS y queremos teclear 
el siguiente programa: 

; COMANDO EXTERNO 



CLS 



; PARA MSX-DOS 

ORG 2000H 

LOAD 2000H 
CALSLT: EQU 001 CH 
CLS: EQU 00C3H 

LD IX, CLS 

LD IY,0 

CALL CALSLT 

RET 

END 

Sigamos los siguientes pasos: 
ZEN>E 

1 ORG 2000H 

2 LOAD 2000H 

3 CALSLT: EQU 

4 CLS: EQU 00C3H 

5 LD IX, CLS 

6 LD IY,0 

7 LD IX, CLS 



8 RET 
9. 

Una vez tecleado esto corregimos 
los fallos. 

Hemos duplicado una línea. 

ZEN>T7 

7 LD IX, CLS 

ZEN>Z 

Falta END al final del programa. 

ZEN>T10 

EOF 

ZEN>E 

8 END 

9 . 

La línea 3 está incompleta. 

ZEN>T3 
ZEN>N 

3 CALSLT: EQU 001 CH 

Antes de ensamblarlo añadimos los 
comentarios para su posterior identi- 
ficación y salvamos el programa fuen- 
te. 

ZEN>T1 
ZEN>E 

1 ; 

2 ; COMANDO EXTERNO 

3 ; 

4 ; CLS 



5 ; 

6 ; PARA MSX-DOS 

7 ; 

8 . 

ZEN>RS 
NAME>CLS 

Lo compilamos. 

ZEN>A 
0PTI0N>V 

Ahora salvamos el programa fuen- 
te. 

ZEN>WC 
START>2000H 
ST0P>200AH 
NAME>CLS 

Salimos del programa y lo proba- 
mos. 

ZEN>B 
A>CLS 

Esta rutina que además de muy cor- 
ta es sencilla, puede ser de gran auy- 
da para mejorar nuestros ficheros 
«.BAT». Sólo tendremos que tener la 
precaución de copiarla con el sistema 
operativo, ya que es un comando ex- 
terno que le añadimos. Su hermano 
mayor MS-DOS ver 3.00 ya posee este 
comando como interno, pero, sólo se 
puede ver con la práctica. 
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Todo se compra y se vende. Los antiguos zocos fueron 
lugares destinados a todo tipo de transacciones. INPUT 
también tiene el suyo. Vuestras operaciones de compra, 
cambio o venta serán publicadas en esta sección, pera dos 
son las limitaciones que imponemos: 

a) La propuesta tendrá que ver con la microinformática. 

b) Nos reservamos el derecho de no publicar aquellos 
insertos de los que se sospeche un trasfondo lucrativo. 

Ahora un ruego. Tratar de resumir al máximo el texto; 
escribir casi como un telegrama siendo claros y concisos. 

Envía tu mensaje a: 

INPUT MSX ZOCO 

P.° de la Castellana, 93 
28046 MADRID 
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BASIC 

Una información indispensable 
del primero al último fascículo. 

BASIC 

Para no ser un extraño en el futuro 
tecnológico que nos aguarda. 

BASIC 

Para poner una nueva ciencia a nuestro 
servicio. 
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5.25 PULGADAS EN TU MSX 



Con la unidad SVI-707 de Spectra- 
video y tu MSX podrás trabajar con 
diskettes del formato de 5.25 pulgadas 
y tendrás la oportunidad de intercam- 
biar algunos ficheros con otros ordena- 
dores que utilicen este formato, por 
ejemplo con todos los compatibles PC. 
¡Interesante verdad! 

El formato elegido por los fabrican- 
tes de ordenadores MSX pá'rá las uni- 
dades de disco y los diskettes que iban 
a incorporar sus equipos fue, desde un 
primer momento, el de 3.5 pulgadas. 
Estas cifras, que hacen referencia al 
tamaño del diskette, corresponden a 
uno de los formatos que, más posibi- 
lidades tiene de convertirse en el es- 
tándar de los próximos años. 

Este formato ha sido el resultado de 
una evolución, caracterizada por la 
búsqueda de un menor tamaño, de 
una mejor protección de la informa- 
ción y al mismo tiempo, de una ma- 
yor capacidad de almacenamiento de 
cada diskette. 

El formato que primero se utilizó 
fue el de 8 pulgadas (más de dos ve- 
ces mayor que el actual). Los disket- 
tes de este formato eran demasiado 
grandes, difíciles de manejar y sin em- 
bargo no eran capaces de almacenar 
demasiada información. 

El paso siguiente consistió en redu- 
cir el tamaño aproximadamente a la 
mitad y dió lugar a la aparición de los 
famosos diskettes de 5.25 pulgadas, 
que fueron los que incorporaron los 
primeros ordenadores personales, en- 
tre ellos el Apple II, los Commodore y 
los primeros Atari. También IBM eli- 
gió este formato para las unidades de 
disco de su línea de ordenadores PC. 

Con ello las 5.25 pulgadas llegaron 
a convertirse rápidamente en el for- 
mato más popular para las unidades 
de disco de la mayoría de los ordena- 
dores personales, liderazgo que se ha 
mantenido hasta nuestros días. Toda- 
vía hoy es el más popular de los for- 
matos de diskettes y sobre el se ha gra- 
bado más información, en forma de 



programas y datos, de la que nunca se 
pudo imaginar. 

¿Por qué entonces las 3.5 pulgadas 
para los diskettes del estándar MSX? 
La respuesta está en que este formato 
es el que mayores posibilidades tiene 
de convertirse en el estándar de los 
próximos años (desplazando a las 5.25 
pulgadas) y ello porque supone una 
mejora en todos los aspectos. En pri- 
mer lugar los diskettes son algo más 
pequeños, lo cual resulta interesante 
para los fabricantes, siempre preocu- 
pados por reducir el tamaño de sus 
equipos (sobre todo en el caso de los 
portátiles). En segundo lugar hay una 
importante mejora en cuanto a la pro- 
tección de la información ya que los 
diskettes de 3.5 pulgadas tienen una 
funda rígida (en lugar de la funda fle- 
xible de los de 5.25) y una chapa me- 
tálica deslizante que oculta la superfi- 
cie magnética del diskette cuando está 
fuera de la unidad (en los de 5.25 la 
superficie magnética queda al descu- 
bierto, expuesta a mil y un peligros). 
La última ventaja está en la mayor ca- 
pacidad de almacenamiento del for- 
mato de 3.5 que actualmente se sitúa 
en torno a 1 Mbyte por diskette (en do- 
ble cara, doble densidad). 

Estas razones, entre otras, han he- 
cho que no sólo los fabricantes de 
MSX sino también firmas como Com- 
modore (con su modelo Amiga) o Ata- 
ri (en sus nuevos equipos ST) hayan 
optado por el estándar de 3.5 pulga- 
das. Hay incluso quien asegura que 
IBM está considerando adoptar los 
diskettes de 3.5 para sus nuevos mode- 
los personales. 



SVI-707 



Spectravideo comercializa las 5.25 
pulgadas en un conjunto formado por 
la unidad de diskettes SVI-707, un nu- 
trido conjunto de manuales que inclu- 
ye el de la propia unidad y los de los 
sistemas operativos MSX-DOS, CP/M 
y MSX Disk BASIC y varios diskettes 
de 5.25 pulgadas con los sistemas ope- 



rativos mencionados y algunos progra- 
mas de utilidad. 

Sin embargo el conjunto no está 
completo, a menos que uno sea usua- 
rio del ordenador SVI-728, ya que el 
conector de la unidad de discos es es- 
pecífico para este ordenador. Para 
realizar la conexión a cualquier otro 
equipo MSX es necesario adquirir el 
cartucho adaptador que suministra la 
propia Spectravideo (a un precio de 
unas 2.000 pesetas) y que lleva el nom- 
bre de SVI-213. Este cartucho recibe 
por uno de sus extremos el conector 
de la unidad y por el otro encaja en 
los slots de cartucho de los MSX. 

La unidad en sí, encerrada en una 
carcasa metálica de color blanco, es 
compacta y robusta. En su parte fron- 
tal, además de la ranura para introdu- 
cir los diskettes, hay un par de diodos 
LED (indicadores luminosos) uno de 
ellos, de color verde, para indicar que 
la unidad está conectada a la red y el 
otro, de color rojo, para señalar que 
se está efectuando un acceso al disket- 
te (en una operación de lectura o escri- 
tura). 

La conexión a la red se efectúa a 
través de un alimentador externo, 
que, en nuestra opinión, hubiera sido 
mejor incluir en la carcasa de la uni- 
dad, pues ocupa espacio, estorba y 
añade cables extra a la maraña que 
siempre tenemos organizada. 



LA UNIDAD EN ACCION 



Una vez efectuadas las conexiones 
necesarias basta poner en marcha el 
ordenador para poder empezar a tra- 
bajar con la unidad. Su funcionamien- 
to, cuando se utiliza como unidad úni- 
ca, no guarda sorpresas. Se comporta 
exactamente igual que las de 3.5 pul- 
gadas. Lo primero que hicimos, tras 
formatear diskettes de 5.25 pulgadas, 
fue utilizar los comandos de MSX- 
DOS, CP/M y Disk BASIC para guar- 
dar y recuperar ficheros de varios ti- 
pos. No encontramos ni un sólo pro- 
blema de funcionamiento, salvo cuan- 



44 INPUT 



S^isto de Hardware 






do probamos la versión CP/M en má- 
quinas que no fueran Spect ra video. Al 
parecer la versión CP/M incluida sólo 
la soportan las máquinas de Spectra- 
video y no el resto de los MSX. Al tra- 
bajar con MSX-DOS y Disk BASIC no 
encontramos ningún problema de 
compatibilidad. Lo que si apreciamos, 
al hacer estos primeros ensayos, fue 
que la unidad es bastante silenciosa 
(algo muy importante) y que arranca 
algo más lentamente que las unidades 
de 3.5 pulgadas. 

El paso siguiente consistió en co- 
nectar simultáneamente, dos unida- 
des: la SVI-707 y una unidad de 3.5 
pulgadas. Nuestra intención era la de 
transferir ficheros de uno a otro for- 
mato de diskette y probar el funciona- 
miento de los programas después de 
las transferencias. En este caso, la uni- 
dad de 5.25 queda normalmente asig- 
nada como unidad A mientras que la 
de 3.5, según el tipo de conexión, que- 
da como unidad C o E. De todos mo- 



dos, tras una sencilla prueba queda 
claro cual es la letra correspondiente 
a cada una de las unidades. 

Arrancamos con el sistema operati- 
vo MSX-DOS desde la unidad A y em- 
pezamos los ensayos. No hubo ni un 
solo problema. Transferimos todo tipo 
de ficheros de uno a otro formato de 
diskette sin que surgiera la menor di- 
ficultad. Hicimos las pruebas con dis- 
tintos equipos, tanto de la primera 
como de la segunda generación MSX. 
Algunos equipos llevaban la unidad de 
3.5 pulgadas incorporada y en otros 
casos había que utilizar una unidad ex- 
terna (entonces conectábamos una 
unidad a cada uno de los dos slots de 
cartucho). Los ficheros copiados (me- 
diante el comando COPY del MSX- 
DOS) ejecutaban perfectamente desde 
cualquiera de los dos formatos de dis- 
kette. En fin, las pruebas resultaron un 
completo éxito, y no hubo ni el más 
mínimo problema de compatibilidad, 
al menos con los equipos que proba- 



mos. No hicimos pruebas con todos 
los MSX existentes, así que no pode- 
mos garantizar que en algún caso de- 
terminado no vayan a surgir pegas. En 
cada caso concreto será conveniente 
asegurarse antes de que existe dicha 
incompatibilidad. 

HACIENDO INTERCAMBIOS CON 
UN PC 

El sigiente conjunto de pruebas que 
llevamos a cabo, y que para nosotros 
resultó el más interesante, estaba des- 
tinado a probar una de las afirmacio- 
nes más atractivas que se han hecho 
sobre el sistema operativo MSX-DOS 
que dice que el formato de grabación 
de ficheros de este sistema operativo 
es compatible con el de otro famoso 
sistema: el archiconocido MS-DOS. 

MSX-DOS es un sistema operativo 
en disco fabricado por Microsoft (los 
mismos que han creado el MSX-DOS) 
que ha llegado a convertirse en el sis- 
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tema más popular de las máquinas de 
16 bits al ser el de mayor uso en los or- 
denadores, IBM PC y compatibles. 

Al lanzar el MSX-DOS, Microsoft 
anunció la compatibilidad de formatos 
con el MS-DOS lo que abría la puerta 
a una serie de interesantes manipula- 
ciones y transferencias de ficheros en- 
tre máquinas tan distintas como un 
MSX y un PC. 

El mayor obstáculo está en que los 
compatibles PC utilizan en general 
unidades de disco de 5.25 pulgadas, 
mientras que los MSX trabajan en 3.5. 
El disponer de la SVI-707 nos iba a 
permitir hacer una conversión de for- 
matos y probar de este modo la com- 
patibilidad. 

Desde luego que esta compatibili- 
dad hay que entenderla como limita- 
da a cietos tipos de ficheros, por ejem- 
plo los ficheros ASCII, sin que en nin- 
gún momento pueda pensarse en la 
ejecución de programas de una máqui- 
na en otra, ya que tanto las CPUs, 
como los mapas de memoria e incluso 



los sistemas operativos, son totalmen- 
te diferentes. 

Así que armados con nuestra 
SVI-707 hicimos un primer intercam- 
bio e introdujimos un diskette de MSX 
en un PC y, al tiempo, uno de PC en 
un MSX. Tecleamos «dir» en ambas 
máquinas y pudimos ver como apare- 
cían los directorios de cada diskette en 
una máquina que no era en la que ha- 
bían sido grabados. La primera prue- 
ba había sido un éxito. 

El siguiente paso fue utilizar dos 
procesadores de texto (la versión 
Wordstar en MSX y el programa Per- 
sonal Editor en el PC) para intentar 
un intercambio de ficheros ASCII. 
Tras grabar unos textos de prueba in- 
tercambiamos los diskettes e intenta- 
mos la lectura. De nuevo el éxito fue 
completo. El texto grabado en el MSX 
aparecía intacto en el monitor del PC 
y viceversa. Con ello dábamos por ter- 
minado el experimento, con el que ha- 
bíamos comprobado que, en efecto, 
los dos sistemas operativos de Micro- 



soft graban en el mismo formato y per- 
miten el intercambio de ciertos tipos 
de ficheros. 



MUCHAS POSIBILIDADES 



La unidad SVI-707 es un sistema 
que permite la conversión entre los 
dos formatos más populares de unida- 
des de disco y diskettes de la actuali- 
dad. Permite además las transferen- 
cias de ficheros entre los sistemas ope- 
rativos MSX-DOS y MS-DOS de una 
forma sencilla y rápida. 

Todo ello a un nivel de precios que 
se sitúa en torno a las 65.000 pesetas 
(incluyendo el precio de la unidad y 
del adaptador para cualquier MSX). 

Las posibilidades que con todo ello 
se abren son inmumerables, especial- 
mente si consideramos entornos pro- 
fesionales en los que las conversiones 
de formato y la coexistencia de MSX 
y PCs, pueden llevar a soluciones muy 
económicas para instalaciones y ámbi- 
tos de programación complejos. 
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MITSUBISHI 
MAP 



ESTRUCTURA DE MAP 



TRATAMIENTO DE TEXTOS 



GESTION DE ARCHIVOS 



HOJA ELECTRONICA 



PROGRAMACION 



El cartucho MAP es una interesan- 
te herramienta, con ella podrás reali- 
zar labores sencillas de tratamiento de 
textos, gestión de archivos, y presenta- 
ción de gráficos. Todo ello desde un 
solo programa. 

MAP se encuadra dentro de los pa- 
quetes integrados de programas de 
gestión que contienen fundamental- 
mente un procesador de textos, una 
base de datos, una hoja electrónica y 
una utilidad de gráficos. Todos ellos 
se organizan en torno a una base co- 
mún de modo que puedan interaccio- 
nar fácilmente entre ellos. 



ESTRUCTURA Y ORGANIZACION 
GENERAL DE LOS PROGRAMAS 



MAP organiza la memoria del orde- 
nador en cuatro zonas de trabajo, lla- 
madas hojas: la de datos, la de forma- 
teo, la de programa y la de fichas. 

La hoja de datos contiene la infor- 
mación que vamos a manejar. Esta in- 
formación puede ser un texto, en el 
caso de que estemos trabajando con el 
procesador de texto, fichas, si utiliza- 
mos la base de datos, contenido de las 
celdas, en el caso de la hoja de cálcu- 
lo, o valores con los que construir los 
gráficos. Este área puede contener 
hasta 100 líneas de información de 120 
caracteres cada una. 

La hoja de formato indica cómo se 
va a disponer la información en las lí- 
neas de la hoja de datos. 

La hoja de programas se usa para 
almacenar los programas MAP, de los 
que hablaremos más adelante. 

La hoja de fichas se usa como un 
buffer temporal para introducir la in- 
formación en la hoja de datos. 

Nosotros podremos introducir in- 
formación en cada una de esas hojas 

EL MENU PRINCIPAL DE MAP 



por separado, así como guardar y re- 
cuperar la inforamción contenida en 
ellas, independientemente. Ello nos 
permite guardar, en diskette o en cas- 
sette, y en archivos independientes, la 
información de datos, de programas o 
de formato. 

Hay que destacar que el programa 
nunca nos va a preguntar cual de las 
cuatro utilidades queremos usar. El 
uso del MAP como procesador de tex- 
to, base de datos, hoja de cálculo o ge- 
nerador de gráficos depende exclusi- 
vamente de la utilización que hagamos 
de los comandos, diferenciándose úni- 
camente en la forma de disponer la in- 
formación en la base de datos. 

Dichos comandos pueden introdu- 
cirse de dos maneras distintas. Puede 
hacerse uso de una tabla general, en 
la que aparecen todos los comandos, 
junto con un icono explicativo a cada 
uno. El comando se selecciona llevan- 
do el cursor a cada icono y pulsando 
RETURN. 

La otra forma de introducir coman- 
dos es dando al ordenador el nombre 
del comando desde el teclado. 



En cualquier momento podemos se- 
leccionar uno de los dos modos ante- 
riores, haciendo uso del comando OP- 
TION. Este comando permite otras 
muchas selecciones, que más adelante 
veremos. 

Vamos a estudiar el uso de MAP en 
cada una de las cuatro opciones men- 
cionadas. 

MAP COMO PROCESADOR DE 
TEXTOS 

Usando MAP como procesador de 
texto, introduciremos directamente 
nuestra información en la hoja de da- 
tos. Esta información, corregidos to- 
dos los posibles errores y formateada 
a nuestro gusto, la volcaremos a la im- 
presora. 

MAP deja automáticamente 10 es- 
pacios en cada margen , por defecto. 
Podemos cambiar el tamaño de már- 
genes que deseemos haciendo uso del 
comando OPTION. También, y con 
este mismo comando estableceremos 
las divisiones de tabulación. 
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MAP COMO TRATAMIENTO DE TEXTOS 



Cuando escribamos nuestro texto 
en la hoja de datos tendremos la po- 
sibilidad de insertar caracteres y lí- 
neas, borrarlos, así como mover o co- 
piar una porción de la hoja de datos 
en otra, y borrar zonas de texto. 

La forma de mover, copiar y borrar 
información merece mención aparte, 
ya que la selección de la zona a modi- 
ficar se efectúa dando la posición su- 
perior izquierda e inferior derecha del 
rectángulo de la hoja de datos que lo, 
engloba. 

Esta forma de marcar una zona en 
la hoja de datos para hacer algo en ella 
es común a todas las aplicaciones de 
MAP. No obstante, puede llegar a ser 
incómoda si el tamaño de la zona a 
mover es grande, pues obliga a mover- 
se por la hoja de datos para marcar los 
límites. 

MAP incluye también la posibilidad 
de hacer un scroll horizontal y verti- 
cal de la información en la hoja de da- 
tos, y puede ofrecer, sobre la panta- 
lla, un esquema comprimido de dicha 
hoja, lo que nos permite localizar rá- 
pidamente donde está la información. 

Deben resaltarse dos características 
importantes del uso de MAP como 
procesador de texto. Una de ellas es 
que, si lo deseamos, MAP evitará la 
división de palabras en el margen de- 
recho pasando automáticamente la pa- 
labra a la línea siguiente si intentamos 
partirla. La otra consiste en la posibi- 



lidad de un alineado del texto en el 
margen derecho cambiando, si es ne- 
cesario, el espaciado entre palabras. 
Estas dos características son seleccio- 
nabas a través del comando OP- 
TION. 

MAP COMO BASE DE DATOS 

Así como antes utilizábamos la hoja 
de datos para guardar el texto a pro- 
cesar, ahora va a contener los elemen- 
tos de información de la base de datos. 

Básicamente, cada elemento de in- 
formación (o ficha) los guardaremos 
en una de las líneas de la hoja de da- 
tos. Disponemos así de 120 caracteres 
por ficha. Esto puede ser poco en al- 
gunas aplicaciones. 

Previamente al uso de la base de da- 
tos, tenemos que decirle a MAP cómo 
queremos organizar la información 
dentro de la línea o ficha; es decir, 
cuantos campos tiene cada ficha y 
cuantos caracteres tienen cada campo. 
Todo esto se realiza mediante el co- 
mando FORMAT. 

Seguidamente introduciremos la in- 
formación de las fichas en la base de 
datos. Esto se puede hacer ficha a fi- 
cha, con el comando PAGING. Se pe- 
dirá la información según lo indicado 
mediante el comando FORMAT. Sin 
embargo (y esto es general a todas las 
aplicaciones de MAP) hay otra mane- 
ra de suministrar la información y es 



editando directamente la hoja de da- 
tos, mediante el comando EDIT. Caso 
de escoger este camino, es responsa- 
bilidad nuestra teclear la información 
en su lugar adecuado. 

Las facilidades de MAP como base 
de datos son las usuales en este tipo 
de aplicaciones, e incluyen el cambio 
y acutalización de la información, la 
localización de una ficha o grupo de fi- 
chas determinado, y la ordenación al- 
fabética o por valor numérico. 

Siempre podremos guardar la infor- 
mación de las hojas de datos y de for- 
mato en diskette o cassette y recupe- 
rarla más adelante, así como imprimir 
las fichas de la base de datos. 

MAP COMO HOJA DE CALCULO 

En esta aplicación la información 
contenida en la hoja de datos se orga- 
niza en celdas, seleccionables por fila 
y columna, cada una de las cuales pue- 
de contener un número o un valor al- 
fanumérico (como indicador del tipo 
de información en la fila o la colum- 
na). 

Análogamente a como hacíamos 
con la base de datos, tendremos que 
instruir a MAP sobre la forma en que 
queremos organizar la hoja de cálcu- 
lo. Esto lo hacemos de nuevo median- 
te el comando FORMAT. Con él di- 
vidiremos los 120 caracteres de cada lí- 
nea en la hoja de datos en tantas cel- 
das como unidades de información ne- 
cesitemos. 

Existen tres formas básicas de intro- 
ducir información en la hoja electró- 
nica. La primera de ellas es de nuevo 
mediante el comando PAGING. En 
realidad, no existe diferencia entre la 
forma de tratar la información de la 
base de datos y de la hoja electrónica, 
siguiendo la filosofía general de MAP. 

Otra forma es, de nuevo, mediante 
el comando EDIT, accediendo direc- 
tamente a la hoja de datos. Esta for- 
ma es útil para dar título a toda una 
fila o columna. 

La tercera forma es con el coman- 
do INPUT, con el que podremos su- 
ministrar los datos de entrada directa- 
mente sobre las celdas de la hoja de 
cálculo que seleccionemos. La forma 
de hacer la selección es la tradicional 
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en MAP: marcando los límites supe- 
rior izquierdo e inferior derecho de la 
zona. 

En cuanto a las facilidades que ofre- 
ce MAP como hoja electrónica se pue- 
den cambiar y actualizar los conteni- 
dos de cada celda, borrar columnas y 
líneas (lo que obliga a actualizar el for- 
mato), y realizar cálculos entre ele- 
mentos de celdas, filas o columnas. 

MAP tiene además implementadas 
las siguientes funciones: 

SUM: Encuentra la suma de todos 
los elementos de una fila o columna. 

AVE: Promedia todos los números 
de una fila o columna. 

MAX: Encuentra el máximo de una 
fila o columna. 




MIN: Encuentra el mínimo de todos 
los elementos de una fila 0 columna. 



GRAFICOS MAP 



MAP permite la presentación auto- 
mática de los datos numéricos existen- 
tes en la hoja de datos en forma grá- 
fica. Se pueden elegir tres tipos de re- 
presentación: diagrama de barras, dia- 
grama de líneas y diagrama de secto- 
res. Además, los diagrams de barras y 
de líneas permiten comparar hasta 5 
magnitudes simultáneamente, repre- 
sentándose por valores y puntos dis- 
tintos. 

Los números se introducen en la 
hoja de datos por cualquiera de los 
procedimientos ya comentados. Una 
vez allí, el comando GRAPH trazará 
el tipo de gráfico seleccionado en la 
pantalla. 

GRAPH nos preguntará qué zona 
de la hoja de datos vamos a represen- 
tar, y si deberá tomar la información 
por filas o por columnas. 



En los gráficos de líneas y de barras 
nos permitirá escoger la escala a utili- 
zar y el punto de comienzo. 

Los gráficos MAP son de muy bue- 
na calidad y podremos sacarlos por 
impresora, para incluirlos en hojas de 
resúmenes, demostraciones, etc. 



PROGRAMAS MAP 



Si vamos a gestionar la inforamción 
siempre de la misma forma pero utili- 
zando distintos conjuntos de datos, 
existe la posibilidad de confeccionar 
un programa MAP y almacenarlo en 
cinta o diskette, para poder utilizarlo 
cada vez que deseemos. 

Para ello usaremos el comando 
EDIT, escribiendo nuestro programa 
en la hoja de programas de MAP. 

Los programas, además de los co- 
mandos, permiten instrucciones espe- 
ciales, tales como: 

Sacar información por pantalla 
(DISPLAY) 

Introducir información desde el te- 
clado (ACCEPT) 

Emitir sonido (BEEP) 



GRAFICOS MAP 
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Tenemos dos instrucciones especia- 
les que permiten alterar el flujo de 
control. Estas instrucciones son: 

GOTO etiqueta 

IF expresión 1 = expresión 2 THEN 
comando 

Como vemos, MAP no nos ofrece 
un control muy amplio sobre el flujo 
de los programas. Sin embargo, estas 
instrucciones serán suficientes para la 
mayoría de nuestros propósitos. 

La limitación de la hoja de progra- 
mas es de 60 líneas, lo cual es de todo 
J)unto escaso para programas un poco 



complicados o largos. Esto es una li- 
mitación seria para las capacidades de 
MAP 



ASI ES MAP 



MAP es un paquete integrado de 
gestión de uso simple, sin pretensio- 
nes. El juego de comandos que ofrece 
es reducido y general, es decir, no de- 
pende del tipo de aplicación que este- 
mos utilizando en ese momento, y to- 
dos los comandos valen en todas las 
aplicaciones. 

Sin embargo, esta simplicidad de 
uso puede hacer que el manejo sea a 
veces engorroso. Se echan en falta 
funciones y comandos más completos. 




Es posible que el afán por uniformizar 
la información a tratar, que es clave 
en MAP, contribuya a dificultar un 
tanto su manejo. Podrían haberse in- 
cluido funciones más orientadas a 
cada aplicación. 

A nuestro juicio, se echa en falta la 
posibilidad de una interacción de la in- 
formación con el dispositivo de alma- 
cenamiento (típicamente diskette) 
para no tener que limitar la capacidad 
de MAP a la memoria física del orde- 
nador. En muchas aplicaciones, ésta 
puede ser insuficiente y obligarnos a 
procesar la información por trozos en 
el cassette o en el disco, lo que puede 
resultar tedioso. 

No queremos desmerecer, sin em- 
bargo, con esto, las capacidades de 
MAP que, con muy poco entrena- 
miento, se puede convertir en un va- 
lioso ayudante para la confección de 
trabajos, de presupuestos, gestión de 
pequeños negocios, preparación de 
demostraciones que incluyan gráficos, 
y un sinfín de aplicaciones más. 
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Mrteügeneia ArtHtóal 



UN PROGRAMA QUE JUEGA 
A LAS CUATRO EN RAYA (I) 



■ 


JUEGOS DE AJEDREZ 


■ CRITERIOS DE EVALUACION 


■ 


ARBOLES DE DECISION 


■ 


LAS CUATRO EN RAYA 


■ 


EL PROGRAMA 



En esta ocasión, vamos a hablar de 
una de las manifestaciones más apasio- 
nantes de la Inteligencia Artificial: los 
juegos de estrategia. En primer lugar 
describiremos sus fundamentos, para 
pasar después a profundizar en su for- 
ma concreta de funcionamiento a par- 
tir de varios ejemplos cercanos a noso- 



tros, con el juego de las «tres en raya», 
o el ajedrez. 

Aunque el ajedrez, como veremos 
más adelante, es uno de los ejemplos 
menos didácticos que podíamos pro- 
poner, sí es de los más interesantes, y 
por ello vamos a empezar por él. 




El programa jugador de ajedrez 
más rápido del mundo (también po- 
dríamos decir que «el mejor»), es el 
llamado Belle, capaz de estudiar en 
torno a las 160.000 posiciones por se- 
gundo y simular sus jugadas y las res- 
puestas del adversario en una profun- 
didad de diecisiete niveles. No obstan- 
te, tan espectacular despliegue de me- 
dios no llega a ser suficiente para de- 
rrotar a los grandes maestros, si bien 
algunos de ellos han reconocido que al 
menos lo han tenido difícil para ven- 
cer. 

El ajedrez, como todos los juegos 
de estrategia, requiere que los jugado- 
res vayan mucho más allá del mero co- 
nocimiento de las reglas y la confian- 
za ciega en la suerte; es necesario tra- 
tar en todo momento de maximizar el 
valor de nuestra posición frente al ad- 
versario, limitando su libertad de ac- 
ción, coartando su iniciativa, y colo- 
cándole en una situación desfavorable 
que se haga susceptible de llevarle a 
la derrota. Ciertamente es muy difícil 
conseguir que una máquina pueda ha- 
cer todo esto mejor que el hombre. 

El único camino posible, que se 
sepa hasta ahora, necesita cubrir dos 
fundamentos básicos: 

LV Establecer una serie de «crite- 
rios de evaluación» (cuantos más, me- 
jor), que permitan al programa valo- 
rar su situación y saber así qué jugada 
es favorable y qué jugada no lo es. 

2°.- Prever sus posibles jugadas re- 
montándose en un árbol de posibilida- 
des, valorando los resultados. 

JUEGOS INTELIGENTES 



La Inteligencia Artificial puede lle- 
gar a hacernos creer que comprende 
conceptos, pero no debemos engañar- 
nos: el ordenador sólo comprende ci- 
fras. Por ello, vamos a hablarle en su 
idioma, el idioma de los números. 
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SERVICIA 



DE 



OS 



¡NO TE PIERDAS NI UN SOLO EJEMPLAR! 



INPUT MSX quiere proporcionar 
a sus lectores este nuevo servicio de 
ejemplares atrasados para que no pierdan la 
oportunidad de tener en sus hogares todos 
los ejemplares de esta revista, líder en el 
mercado español. 

Podréis solicitar cualquier número de 



INPUT MSX que queráis, siempre al precio 
de cubierta (sin más gastos). 

Utiliza el cupón adjunto, enviándolo a 
EDISA (Dpto. de Suscripciones), López de 
Hoyos, 141 - 28002 Madrid, o bien llámanos 
por teléfono al (91) 415 97 12. 



INPUT 





P 

■til 



CUPON DE PEDIDO 



SI, envíenme contrarreembolso 
MSX de los números: 

(marca con una (X) tu elección) 



ejemplares de INPUT 





Vigencia Artificial 



Para que sepa de alguna manera lo 
que es bueno y lo que es malo, lo que 
conviene y lo que no conviene hacer, 
lo que un adversario listo podría ha- 
cer, y lo que no haría nunca, es nece- 
sario que posea una serie de criterios 
que le permitan valorar en cifras una 
situación dada. En el caso del ajedrez, 
se pueden llegar a considerar hasta se- 
senta criterios, como por ejemplo los 
siguientes: 

- Libertad de acción (número de ju- 
gadas posibles y favorables que pode- 
mos hacer) 

- Protección de las figuras 



FIGURA 1 




2 PUNTOS 



superable. Además, la sencillez de es- 
tos dos juegos nos va a permitir pro- 
fundizar más en lo que hemos visto 
hasta ahora. 

Como el juego de las tres en raya es 
quizás demasiado simple, y como ade- 
más siempre acaba en tablas, vamos a 
utilizar el de las cuatro en raya, aun- 
que no el tradicional, sino una espe- 




2 PUNTOS 



cié de mezcla entre el primero y el se- 
gundo. 

En la figura número l podemos ver 
una serie de alineamientos. A cada 
uno de ellos le otorgamos un valor nú- 
merico según sea más o menos bueno, 
es decir, en razón a las ventajas que 
presenta con vistas a completar la lí- 
nea de cuatro cruces: 

El primer alineamiento es el más 
sencillo y también el menos favorable, 
ya que consta de sólo dos cruces y par- 
te de una esquina. El segundo vale el 
doble que el primero (dos) porque, al 
no partir de un lateral, hace posible 
continuar la línea por cualquiera de 
sus dos extremos. Por esta misma ra- 
zón, el cuarto alineamiento es el que 
más valor tiene, pues basta con colo- 
car otra cruz en uno de los extremos 
de la línea para ganar la partida (ali- 
neamiento 5). 

A partir de estos presupuestos, 
¿cómo desarrolla la máquina su estra- 
tegia? 



Antes de responder a la pregunta, 
conviene que aclaremos un poco el 
significado de lo que los especialistas 
llaman «Juegos bipersonales de suma 
nula». Simplificando, podríamos decir 
que son aquellos juegos (mejor diría- 
mos «relaciones», pues se trata de una 
teoría aplicada más a la toma de deci- 
siones sobre situaciones reales, que a 
los «juegos» (gantes) propiamente di- 
chos), en los que existen dos adversa- 
rios, o dos intereses opuestos, de for- 
ma que la desventaja en la que se en- 
cuentre un jugador determina en qué 
medida le lleva el otro ventaja y vice- 
versa. Es decir, si puntuamos con nú- 
meros positivos y negativos el valor de 



la situación es siempre nula. Veámos- 
lo con un ejemplo: 

Si el jugador A tiene un alineamien- 
to del tipo 4 (seis puntos), y el juga- 
dor B uno del tipo 3 (tres puntos), el 
valor de la situación de A será 

6-3 = 3 

y la de B 

3 - 6 = -3 

luego 

3 + (-3) = 0 

Vayamos ahora a la figura número 
dos. 

El ordenador juega con las blancas 
y nosotros con las negras. Le toca mo- 
ver a él. Comienza por ver qué juga- 



- Control del centro del tablero 

- Amenaza sobre las figuras enemi- 
gas, etc. 

Se hace evidente que los algoritmos 
capaces de hacer un trabajo tan árduo 
y minucioso han de ser formidable- 
mente rápidos, ya que de lo contrario 
el ordenador tardaría una eternidad 
en darnos su respuesta y el programa 
perdería así gran parte de su utilidad. 
Sería un buen ejercicio didáctico en- 
sayar estos conceptos en BASIC, pero 
los resultados nunca serían satisfacto- 
rios. En cambio, en un juego menos 
complicado, como el «cuatro en raya» 
o el «tres en raya», la lentitud del BA- 
SIC sería un obstáculo perfectamente 



3 PUNTOS 
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das puede hacer y cuánto puntúa cada 
una, llegando a la conclusión de que 
colocando la ficha en (3, A) obtiene la 
jugada de valor más alto (tres puntos). 
Ahora se pone en el lugar del contra- 
rio y busca la jugada más favorable 
que podrían hacer las negras si las 
blancas colocaran en (3, A). Induda- 
blemente, las negras colocarían en 




6 PUNTOS 



(1,B), obteniendo una jugada de seis 
puntos. De esta forma, el ordenador 
sabe que la ganancia del contrario se- 
ría mayor que la suya si realizara esa 
jugada (3 - 6 = -3), y decide, por 
tanto, «taponar la jugada del contra- 
rio» situando un ficha blanca en (1,B)- 
Resumiendo, el ordenador busca su 
mejor jugada para buscar después la 
mejor jugada del contrario y restar el 
valor de ambas; si el resultado es po- 
sitivo, hace su jugada, y si es negati- 
vo, evita que el contrario haga la suya. 

Resulta muy evidente lo fácil que 
sería ganar a un programa que utiliza- 
ra un algoritmo tan sencillo como éste. 
Sin embargo, basta decir que amplian- 
do su profundidad de previsión de ju- 
gadas futuras y añadiéndole algún cri- 
terio de evaluación más, sería prácti- 
camente invencible. Por ejemplo, se 
podría dar una puntuación especial 
por la posesión del centro del tablero. 

La determinación de criterios de 
evaluación y la aplicación de algorit- 



mos del tipo «juegos bipersonales de 
suma nula», son fundamentos válidos 
para la mayoría de los juegos de es- 
trategia. En esencia, el funcionamien- 
to de los programas de este tipo no di- 
fiere en mucho del ejemplo que hemos 
analizado en este capítulo. 

10 REM CUATRO EN RAYA. 

ERNESTO DEL VALLE - INPUT. 
1986 

20 REM NOTA IMPORTANTE- 
TECLEAR Y EJECUTAR EL 
PROGRAMA EN MODO 
"MAYUSCULAS" (CAPS LOCK) . 

30 SCREEN 1: TT=1:DIM A(7,4) 

40 GOTO 9000 




VICTORIA 



1065 IF TA=3 AND U=0 THEN V=1 

: GOTO 1800 
1068 IF UU=1 GOTO 2500 
1070 IF U=0 THEN U=1 : GOTO 

1030 
1075 G0SUB 1800 
1080 TT=TT+1 
1090 T=2: GOTO 2000 
1100 REM RUTINA DE ANALISIS Y 

VALORACION 

1102 IF F=4 G0T0 1105 

1103 IF A(N,F+1)=0 THEN 
UU=UU-1: RETURN 

1105 C=0: X=N: Y=F 
1110 X=X+1: G0SUB 1500 
1112 IF R=0 GOTO 1110 
1115 X=N: Y=F 
1120 X=X-1: G0SUB 1500 
1122 IF R=0 GOTO 1120 
1125 C=0: X=N: Y=F 
1130 X=X-1 : Y=Y-1 : G0SUB 
1500 

1132 IF R=0 GOTO 1130 
1135 X=N: Y=F 
1140 X=X+1: Y=Y+1: G0SUB 
1500 

1142 IF R=0 GOTO 1140 
1145 C=0: X=N: Y=F 
1150 X=X-1: Y=Y+1: G0SUB 
1500 

1152 IF R=0 GOTO 1150 
1155 X=N: Y=F 
1160 X=X+1: Y=Y-1 : G0SUB 
1500 

1162 IF R=0 GOTO 1160 
1165 C=0: X=N: Y=F 



FIGURA 2 
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REM MI TURNO 
IF T=2 GOTO 2000 
V=0: C=0: LOCATE 0,1: 
PRINT "MI TURNO ": 
TF=0: TA=0 

IF TT=1 THEN NN=4: FF=4: 

G0SUB 1800: T=2: GOTO 

2000 

UU=0 

U=0 

F0R N=0 T0 7 
F0R F=0 T0 4 

IF A(N,F)=0 THEN UU=UU+1 
:G0SUB 1100 
NEXT F 
NEXT N 

IF UU=0 GOTO 2500 



A B C D E 

0 9 Q O O 9 



1 6 (ó) 



2 0 6 
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UNA 
OPORTUNIDAD 
IRREPETIBLE 



Ahora tienes la ocasión de hacerte con los 
10 mayores éxitos del año 
en su presentación original 
(cada uno en su estuche y con su carátula) 
a un precio de auténtico chollo: 3.995 pts. 

Imagínate... Los 10 mejores títulos de 1986 
por poco más de lo que cuesta uno solo. 

¡¡¡PIDE EL SUPER-10 EN TU TIENDA 
ANTES QUE SE AGOTE!!! 



"SUPER-10" SPECTRUM 

EXPLODING FIST 
TURBO ESPRIT 
ROCK'N LUCHA 
ZORRO 
3 WEEKS IN PARADISE 
ABU SIMBEL (PROFANATION) 
SABOTEUR 
CAULDRON II 
BRUCE LEE 
SPY HUNTER 

"SUPER-10" COMMODORE 

EXPLODING FIST 
URIDIUM 
GOONIES 
SABOTEUR 
BEACH HEAD II 
CRITICAL MASS 
SPY HUNTER 
ZORRO 
SUPER-ZAXXON 
FIGHTING WARRIOR 



"SUPER-10" AMSTRAD 

EXPLODING FIST 
TURBO ESPRIT 
ROCK'N LUCHA 
ZORRO 
3 WEEKS IN PARADISE 
ABU SIMBEL (PROFANATION) 
SABOTEUR 
CAULDRON II 
BRUCE LEE 
RAID OVER MOSCOW 

"SUPER-10" M.S.X. 

ALIEN-8 
KWIGHT LORE 
GUNFRIGHT 
NIGHTSHADE 
JACK THE NIPPER 
SHOWJUMPER 
VALKYR 
BOUNDER 
MAPGAME 
JET SET WILLY II 



^0 




1170 
1172 
1175 

1179 
1180 

1190 
1500 



1502 
1505 

1508 



Y=Y-1: GOSUB 1500 

IF R=0 GOTO 1170 

X=N: Y=F 

R=0 GOTO 1178 

C=0: X=N: Y=F 

IF TF>TA THEN TA=TF: 

NN=N: FF=F 

F=4 : RETURN 

G=(1 AND X<0)+(1 AND X>7 

)+(1 AND Y<0)+ 

(1 AND Y>4) 

IF G>0 GOTO 1520 

IF A(X,Y)<>1 AND U=0 

GOTO 1520 

IF A(X,Y)<>2 AND U=1 
GOTO 1520 



1510 
1515 
1520 
1530 
1800 



1802 
1805 



1808 
1809 
1810 
1815 



R=0: C=C+1 
RETURN 

IF OTF THEN TF=C 
R=1 : RETURN 

REM RUTINA FINAL DE MI 
TURNO. COMPROBACION DE 
VICTORIA E IMPRESION DE 
FICHA 

IF V<>2 GOTO 1810 

CLS: PRINT "ME HAS 

GANADO": PRINT"PULSA UNA 

TECLA": BEEP 

IF INKEY$="" GOTO 1808 

RUN 

X=(NN*3)+2 
Y=(FF*3)+4 



1820 LOCATE X,Y:PRINT CHR$(1) 

;CHR$(65) 
1830 A(NN,FF)=1: BEEP 
1840 IF V<>1 THEN RETURN 
1850 CLS: PRINT "TE HE GANADO 

": PRINT "PULSA UNA 

TECLA": BEEP 
1860 IF INKEY$="" GOTO 1860 
1870 RUN 

A continuación publicamos ia pri- 
mera parte de un programa «inteligen- 
te», capaz de jugar a las «Cuatro en 
Raya». En el próximo número lo com- 
pletaremos con el resto del listado y 
las instrucciones de manejo. 
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INPUT 



LOS MEJORES 
DE INPUT MSX 

PUESTO TITULO PORCENTAJE 

í.° KnightLore 17,8% 

2° H.E.R.O. 13,4% 

3. ° Soccer 13,4% 

4. ° Profanation 12,3% 

5. ° Alien 8 11,9% 

6. ° Jack the Nipper 8,8 % 

7. ° Hyperrally 6,7% 

8. ° y/e ar kung fu 6,3% 

9 o Road Fighter 5,5% 

10.° Yie ar Kung fu II 3,9% 



100% 

Para la confección de esta relación únicamente se 
han tenido en cuenta las votaciones enviadas por 
nuestros lectores de acuerdo con la sección «Los 
Mejores de Input». 

Noviembre de 1986. 



^ Revisto de 



OTRA CLASE DE SOFT 



Desde ahora mismo tienes la posibi- 
lidad de trabajar, en tu MSX, con los 
programas más famosos de la historia 
de la informática. Los títulos, versio- 
nes en diskette de 3.5 pulgadas para el 
sistema operativo MSX-DOS, son tan 
increíbles como: Wordstar, dBASE II, 
Multiplan, Turbopascal,... ¡Es otra 
clase de Software! 

Spectravideo, la primera firma que 
se ha decidido a comercializar estos 
excelentes programas, en versión 
MSX, nos ha hecho llegar unos cuan- 
tos de los nuevos títulos que desde 
ahora mismo pone a disposición de to- 
dos los usuarios del estándar. 

Todos los programas vienen en ver- 
sión diskette de 3.5 pulgadas y prepa- 
rados para trabajar bajo el sistema 
operativo de disco MSX-DOS. Es pro- 
bable que nunca lleguemos a ver ver- 
siones en cassette, puesto que se trata 
de programas que requieren frecuen- 
tes accesos al diskette para leer y es- 
cribir información (o partes determi- 
nadas del propio programa, que van 
cargándose en memoria de forma su- 
cesiva, sólo cuando se hace necesario, 
en lo que se conoce como técnica de 
overlays). El uso de un cassette haría 
prácticamente imposible el funciona- 
miento de este excelente soft y, aun- 
que fuera posible conseguirlo, sería a 
costa de la velocidad y conduciría a 
versiones excesivamente lentas. 

Los programas funcionan perfecta- 
mente tanto en las máquinas de la pri- 
mera como en las de la segunda gene- 
ración MSX (lo único necesario es la 
citada unidad de diskettes). Probable- 
mente, el mayor problema para los 
usuarios de máquinas de la primera 
generación sea el no disponer del for- 
mato de 80 columnas. 

Todos los programas están pensa- 
dos para trabajar en este formato y 
aunque pueden hacerlo perfectamen- 
te en 40 columnas, es a costa de la ca- 
lidad en la presentación. 

En cualquier caso, los usuarios de 
la primera generación pueden hacer 



uso de alguno de los cartuchos de 80 
columnas disponibles en el mercado y 
sacar con ello el máximo partido de 
cada una de estas obras maestras del 
soft. 

En artículos sucesivos iremos co- 
mentando a fondo cada uno de estos 
programas, haremos pruebas de com- 
patibilidad y trataremos aspectos par- 
ticulares de cada versión. Pero no que- 
ríamos dejar pasar la oportunidad de 
daros una panorámica completa de 
este nuevo soft (nuevo en su versión 
MSX), que sin duda abrirá nuevos ho- 
rizontes a muchos usuarios con inquie- 
tudes. 



WORDSTAR 



Para quien no conozca este nombre 
legendario, diremos que se trata del 
programa de tratamiento de textos 
más famoso de la historia de la infor- 
mática. Para los usuarios de MSX es 
una novedad que, sin duda, desplaza- 
rá a todos los programas de tratamien- 
to de textos comercializados hasta 
ahora. 

La versión para MSX-DOS es per- 
fecta. Cumple con todas las caracterís- 
ticas del programa, es veloz, comple- 
ta, viene bien documentada, incluye 
todas las opciones de las versiones 
para máquinas de 16 bits y convierte 
al MSX en una poderosísima herra- 
mienta para la edición, correción, al- 
macenamiento e impresión de todo 
tipo de textos escritos, documentos, 
cartas, etc. 




En este caso, el uso de las 80 colum- 
nas, aunque no imprescindible, se 
hace verdaderamente necesario si lo 
que se desea es trabajar con comodi- 
dad. 

Otro aspecto interesante es la com- 
patibilidad que existe entre los fiche- 
ros de textos almacenados por esta 
versión y los de los ordenadores PC 
(compatibles IBM). En las pruebas 
realizadas y con la ayuda de una uni- 
dad de diskettes de 5.25 pulgadas pu- 
dimos transferir textos entre PCs y 
MSX sin que surgiera la menor dificul- 
tad. 

En definitiva, un programa de tra- 
tamiento de textos con características 
altamente profesioneles y con unas 
posibilidades que dejan fuera de jue- 
go a los programs de este tipo existen- 
tes en la actualidad. 



dBASE II 



Se trata de uno de los mejores pro- 
gramas de gestión de bases de datos 
desarrollado para ordenadores perso- 
nales. Basado en los modelos relació- 
nales y ajustándose bastante bien a lo 
que se conoce como un modelo com- 
pleto, dBASE II ofrece un entorno 
para trabajar con varias bases de da- 




tos, cada una de ellas formada por un 
conjunto de ficheros relacionados, en 
los que podremos guardar toda la in- 
formación que deseemos a través de 
registros y campos. 

De nuevo, la versión MSX es per- 
fecta. Se ha sacrificado algo en cuan- 
to a los límites máximos de utilización 
(número máximo de registros, etc.) 
pero nada o casi nada en presentación, 
velocidad y capacidad de gestión. 
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Avista d e Softwcire^ 



De nuevo hay que hablar de com- 
patibilidad con los PCs a nivel de fi- 
cheros ASCII. 

Como comentario basta decir que 
esta versión deja obsoletos a todos los 
programas de gestión de bases de da- 
tos que existen para MSX. 



MULTIPLAN 



Junto a un programa de tratamien- 
to de textos y un sistema de gestión de 
bases de datos, no podía faltar un 
buen programa de los denominados 
«hoja electrónica» u «hoja de cálcu- 
lo». 

En este caso Spectravideo nos ofre- 
ce la versión de Multiplan, uno de los 

programas de mayor éxito en máqui- 
nas de 16 bits y de los que mayor po- 




pularidad han alcanzado entre toda 
una generación de ejecutivos, empre- 
sarios, profesionales, e.tc. 

Aunque se ha sacrificado algo de 
capacidad, por las limitaciones de me- 
moria de los MSX, el resto de las ca- 
racterísticas del programa siguen in- 
tactas. 



TURBOPASCAL 



Lste programa, de la firma Borland, 
está reputado como la mejor versión 
de lenguaje PASCAL que se hay di- 
señado nunca para ordenadores perso- 
nales. 

El programa proporciona un exce- 
lente entorno para la programación en 
este lenguaje. Entre los programas in- 
cluidos hay que destacar un editor 
(que ha llegado a cobrar fama por sus 
posibilidades como programa de trata- 



miento de textos) y un velocísimo 
compilador, que en cuestión de segun- 
dos compilará los programas fuente, 
en lenguaje PASCAL, introducidos 
desde el editor. 

Para hacerse una idea de las posibi- 
lidades de este increíble programa, 
podemos mencionar que un gran nú- 
mero de serios proyectos de progra- 




■ 



maeión, tanto en la empresa privada 
como en la universidad, se han desa- 
rrollado y se siguen desarrollando con 
esta versión del lenguaje PASCAL, 
eso si, utilizando máquinas con CPUs 
de al menos 16 bits. 



LOS PROGRAMAS NEVADA 



Se trata de un conjunto de cuatro 
programas, tres de ellos dedicados a 
otros tantos lenguajes de programa- 
ción y el cuarto destinado a la edición 
de textos, de la firma estadounidense 
Ellís Computing. Sus nombres son: 
Nevada FORTRAN, Nevada COBOL, 
Nevada PASCAL y Nevada EDIT. 

Los tres primeros están dedicados a 
los lenguajes de programación que les 
dan nombre, e incluyen una serie de 
subprogramas que dan origen a los 
distintos entornos de programación. 
En todos ellos hay un editor para la 
confección de los programas fuente y 
un compilador que se encarga de la 
transformación del programa fuente 
en programa objeto. 

Son programas de altas prestacio- 
nes, con una presentación verdadera- 
mente profesional y unas excelentes 
características de velocidad, flexibili- 
dad, sencillez de manejo, etc. En este 
primer acercamiento diremos sobre 
todo que se trata de versiones muy su- 



periores a las que circulan actualmen- 
te por el mercado, comparables en ca- 
lidad a la mencionada versión de Tur- 
bopascal. 

Nevada EDIT, por su parte, es un 
sencillo editor de textos para MSX- 
DOS, destinado a servir como editor 
de propósito general, tanto para la 
edición de programas fuente, de fiche- 
ros de comandos e incluso de ficheros 
de textos sencillos. 



ALGO MAS DE MICROPRO 



De Micropro, los creadores de la 
versión Wordstar arriba mencionada, 
Spectravideo comercializa además los 
programas Calcstar, Datastar, Re- 
portstar. Se trata respectivamente de 
una hoja electrónica, un sistema de 




gestión de bases de datos y un progra- 
ma para la generación de informes. 

Las primeras impresiones sobre es- 
tos programas son que mantienen la 
calidad y las excelentes prestaciones 
de la versión Wordstar, muy superior 
a los niveles a que nos tienen acostum- 
brados en MSX. 

Habrá más comentarios y un análi- 
sis en profundidad de este soberbio 
conjunto de programas. 
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Revisto de Soft ware^ 



EL CABALLERO DE LA TABLA 
POLIGONAL 



Con este juego te transformarás en 
el Caballero Mágico. Tu deseo de 
aventuras te ha llevado hasta el reino 
de Ibisima. 

El rey de Ibisima no sabe que 
regalarle a su hija Germinitrude. Tu 

misión será encontrar un regalo 
digno de ella en el castillo de 
Duendilandia. Sólo asi lograrás el 
favor del rey que, en 
agradecimiento, te nombrará 




DATOS GENERALES 

TITULO Finders Keepers 
FABRICANTE Mastertronic 

CLASE DE PROGRAMA 

Juego 

FORMATO Cassette 



CALIFICACION (Sobre 10 ptos.) 



ORIGINALIDAD 

INTERES 

GRAFICOS 

COLOR 

SONIDO 



TOTAL 



39 



miembro de la Tabla Poligonal de 
Ibisima. 

Nada más comenzar serás 
transportado al castillo, donde 
tendrás que arreglártelas tú solo, 
buscando el camino adecuado a 
través de todas sus salas. 
En ellas encontrarás monstruos 
terribles y criaturas que 
continuamente se cruzarán contigo 
robándote tu energía. ¡Cuidado, pués 




si el Caballero Mágico pierde su 
energía, morirá! 

En todas las salas irás encontrando 
objetos, que podrás examinar y 
recoger si te interesa, para más tarde 
poder comerciar con los mercaderes 
fantasmas. Ellos te ofrecerán dinero 
por tus tesoros, y tu podrás 
vendérselos si lo deseas. 
¡Cuidado con los laberintos! La reina 
los ha llenado de trampas para que 
no puedas llevar el regalo a la hija 
del rey. 

Al final, podrás elegir entre dos 
opciones: o escaparte del castillo de 
Duendilandia con todas las riquezas 
que puedas, o entregárselas al rey, 
para que éste se las de a su hija. De 
ti depende escoger la acción más 
adecuada... ¡Suerte, futuro caballero 
de la Tabla Poligonal! Te auguramos 
ratos muy divertidos en el reino de 
Ibisima. 



*********************** 



LAS TRES LUCES DE GLAURUIMG 



Se trata de un estupendo programa, 
adaptado a MSX desde su versión 
original para el ordenador Spectrum, 
que narra las aventuras de un 
intrépido caballero, perdido en 
alguna de las vastas y silenciosas 
salas del tenebroso dominio del 
señor del mal... 

Este argumento hace referencia a la 



primera característica del juego, que 
es uno más de la interminable serie 
de programas en los que un 
personaje se mueve explorando las 
salas de alguna construcción, más o 
menos extraña y compleja. 
En su exploración a través de las 
distintas habitaciones, el jugador 
tiene que encontrar tres joyas y una 



llave. Con estos elementos en la 
mano y sólo cuando tenga todos 
ellos, el jugador podrá acercarse 
hasta la salida y escapar. 
Para entorpecer esta búsqueda y 
evitar que el protagonista escape 
fácilmente, los programadores han 
incluido una serie de enemigos, de 
distintas características, a los que 
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tendrá que enfrentarse el jugador, ya 
sea directamente con sus armas o 
utilizando alguno de los objetos que 
consiga recoger. 
El arma más poderosa con que 
cuenta el jugador es su arco. Las 



habitaciones. Para dar más emoción 
al asunto de los cofres, algunos de 
ellos, en lugar de contener un objeto 
útil, están llenos de desagradables 
sorpresas, así que cuidado con 
ellos. 




movimiento de los distintos 
personajes, que resulta poco suave y 
un tanto incontrolable, sobre todo 
cuando se desea saltar. 
En conjunto resulta un programa 
bastante bueno, de características 
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flechas que dispare con él 
neutralizarán a la mayoría de los 
enemigos, salvo a dos de ellos: 
el Mago y el Dragón. Para 
derrotar a estos es necesario 
además llevar alguna de las tres 
joyas. 

Estas joyas y el resto de los objetos 
que el aventurero puede transportar, 
los encontrará en el interior de una 
serie de cofres desperdigados por las 



UNO, DO! 

En los tiempos que corren, tener 
unos kilos de más o simplemente no 
estar en forma, significa estar pasado 
de moda. Idealogic lo sabe y por 
ello, uno de los primeros títulos de 
su línea de programas para MSX2, 
creado especialmente para el 
segunda generación de Philips, es 
este divertido Aerobios, un programa 



El apartado gráficos merece algunos 
comentarios. Al ser una adaptación 
de la versión original Spectrum, hay 
bastantes aspectos de este 
ordenador, que podrían haberse 
resuelto de forma mucho más 
brillante aprovechando las 
posibilidades de los MSX. 
Los gráficos y los escenarios son 
bastante buenos, y hacen buen uso 
del color. Quizás lo más flojo sea el 



original con el que ambas empresas 
intentan ayudarnos a mantenernos en 
forma. 

Aerobics nos presenta en la pantalla 
del televisor a una simpática 
«profesora», que se encarga de 
mostrarnos cómo se hacen los 
distintos ejercicios, de acompañarnos 
en su ejecución y de dirigir, en fin. 



medias, pero sin pegas. Todos los 
aspectos conflictivos han sido 
resueltos a la perfección. El número 
y el aspecto de las distintas salas que 
componen el mapa es un punto 
fuerte que por sí solo proporciona la 
necesaria variedad. 
Otro aspecto interesante es que se 
puede avanzar y pasar de una sala a 
otra sin excesiva dificultad, al menos 
en las primeras salas. 



toda la sesión de aerobic. 
El programa, del que nos ha llegado 
una primera versión en diskette de 
3.5 pulgadas, comienza, tras una 
presentación con imagen digitalizada 
de los autores, por ofrecernos un 
menú con tres niveles de dificultad 
de los ejercicios. 
Seleccionado uno de ellos, da 



*********************** 

DOS, ARRIBA, ABAJO 
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R^istade Software 



comienzo la sesión con la aparición 
de la profesora sobre un fondo que 
representa a un gimnasio, al tiempo 
que empieza a sonar alguna de las 




melodías disco incluidas en el 
programa y destinadas a marcar el 
ritmo de los ejercicios. 
La sesión comienza por un 
precalentamiento y sigue con una 




serie de ejercicios específicos 
destinados a las distintas partes de 
nuestra anatomía (brazos, piernas, 
cintura, estomago, nalgas,...), y así 
hasta que termina la sesión. 




en la poltrona, coger el joystick é 
intentar los ejercicios a base de 
muñeca. Pues no, de lo que se trata 
es de, después de habernos puesto el 
chandal, imitar los movimientos que 
la profesora hace para nosotros. 
Gráficos, animación y sonido son las 
bases de todo el programa, uno de 
los primeros que intenta aprovechar 
a fondo las posibilidades de un 
MSX2. El modo gráfico elegido ha 
sido SCREEN 7 (512x212 puntos en 
16 colores) y el mayor logro es la 
animación de la imagen móvil de la 
profesora. Al parecer, el equipo de 
diseño gráfico se dedicó a estudiar 





DATOS GENERALES 




TITULO Aerobios 






FABRICANTE Idealogic 






CLASE DE PROGRAMA 






Para estar en forma 






FORMATO Cassette o Diskette 














CALIFICACION (Sobre 10 ptos ) 




ORIGINALIDAD 


9 




INTERES 


10 




GRAFICOS 


10 




COLOR 


9 




SONIDO 


10 




TOTAL 


48 









Seguro que alguno está pensando 
que lo que hay que hacer es sentarse 



las distintas posiciones de cada uno 
de los ejercicios, con el fin de 
reproducir lo más fielmente posible 
los movimientos reales. Algo flojo 
resulta el escenario de fondo, único e 
inmóvil, que acaba resultando 
demasiado conocido. El programa 
habría ganado mucho en variedad de 
haber incluido algún escenario más. 
La música disco que acompaña los 
ejercicios, ha sido compuesta por un 
profesional, perteneciente al 
conjunto español de nombre 
Atlanta. 



Los distintos temas, que sincronizan 
perfectamente con el movimiento de 
la profesora incluso al variar la 
velocidad del mismo, están 




magníficamente realizados aunque, 
(quizás sea inevitable por las 
limitaciones del chip de sonido) 
resultan en conjunto poco 
brillantes. 




Los distintos niveles de dificultad, la 
secuencia y la duración de los. 
diferentes ejercicios, temas que 
supervisó una conocida revista 
dedicada a la gente sana, son 




también algunos de los puntos 
fuertes de este soft. 
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INPUT 





Si quieres ver ¿3> tus programas, 



o artículos, 



tu revista, 



bases y haznos llegar 






publicados en 



examina 





el material. 



Publicar tiene su recompensa^ 





PROGRAMAS: Una vez desarrollado tu programa, 
que debe ser original y no haber sido enviado a ninguna 
otra publicación, puedes enviárnoslo aquí grabado en 
cassette, diskette o microdrive. Es preferible que vaya 
acompañado por un listado de impresora, pero no es 
imprescindible. 

El programa habrá de venir acompañado por un texto 
que aclare cuál es su objetivo, el modo de funciona- 
miento y una explicación del cometido que cumplen las 
distintas rutinas que lo componen. El texto se presenta- 
rá en papel de tamaño folio y mecanografiado a dos 
espacios. No importa que la redacción no sea muy clara 
y cuidada; nuestro equipo de expertos se encargará de 
proporcionarle la forma más atractiva posible. 
ARTICULOS E IDEAS: Se aplica lo anteriormente 
dicho para los textos que acompañan a los programas; 
es decir, conviene detallar al máximo lo que desees que 
aparezca publicado en la revista, de la manera que te 
gustaría que otra persona hubiera explicado eso mismo. 
UN JURADO propio decidirá en cada momento qué 
colaboraciones reúnen los requisitos adecuados para su 
publicación, y evaluará la cuantía del premio en metáli- 
co al que se hagan acreedoras. 

No olvidéis indicar claramente para que ordenador está 



preparado el material, así como vuestro nombre y 
dirección y, cuando sea posible, un teléfono de contac- 
to. Entre todos los trabajos recibidos durante cada mes 
SORTEAREMOS: 

• Un premio de 50.000 ptas. 

• Un premio de 25.000 ptas. 

• Un premio de 10.000 ptas. 

en material microinformático a elegir por 
los afortunados. 

¡No os desaniméis!, por muy simples o complejas que 
puedan parecer vuestras ideas, todas serán revisadas 
con el máximo interés. 



INPUT MSX 

Paseo de la Castellana, 93. Planta 14 
28046 MADRID 



NOTA: INPUT no se responsabiliza de la devolución del 
material que no vaya acompañado por un sobré adecuado con 
el franqueo correspondiente. 
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Vendo ordenador Spectravídeo SVI 728 
MSX + manual inglés + manual espa- 
ñol -i- libro de programación + cartu- 
cho Track & Field I (Sony) + 40 progra- 
mas de los mejores por 40.000-45.000 
ptas. a convenir. También cambio-ven- 
do juegos en cinta, poseo más de 80 tí- 
tulos. Llamar o escribir a: 

Jordi Ferran 
Matajudáica, 10 
Tel. (972) 63 01 70 
De 8 a 22 horas 
Girona 



Cambio Pitfall II por cualquier otra cin- 
ta de Activision o Zaxxon. 

Daniel Mañero 
Tel. (91) 797 48 21 



Vendo/Cambio programas MSX, pri- 
meros títulos del mercado. 

Iñaki Fernández Izquierdo 
Zamakoa, 7, 5 o dcha. 

Tel. (94) 456 33 72 
Galdácano (Vizcaya) 



Intercambio y vendo programas, tanto 
de juegos como de aplicaciones: Alien 
8, Abu Simbel, Zen Assembler, Base de 
Datos, etc. 

Suintila García Pulido 
San Marcos, 7, 9-5 
Badalona (Barcelona) 



Vendo por 1.000 ptas. más gastos de 
envío juegos como: Stop the Express, 
Pastfinders, Sorcery, Le Mans, etc. o 
cambio por Zaxxon, Nightshade, Gun- 
fright o Knight Lore. Llamar o escribir a: 
José Ramón Carrillo 
Montornés 33-35, 1 o , 1 8 
Tel. (93) 211 21 97 
08023 Barcelona 



Intercambio juegos (más de 100). To- 
dos primeras marcas (Hiper Sport 1,2,3, 
Yie Ar Kung-Fu 1 y 2, Roller Ball). 

Ricardo Pérez 
Tel. (965) 80 02 82 



azoco 

Cambio juego Le Mans (carreras, muy 
interesante, gráficos 3D) 48K cassette, 
por The way of the Tiger, Turmoil, Pit 
fall II, Knight Lore, Hero o alguno de ka- 
rate. Además vendo libro MSX-Logo 
por el módico precio de 700 ptas. (135 
páginas). Llamar a: 

Juan Ramón Oriach 
Tel. (973) 74 03 16 (de 9.15 a 10.30) 
Almacellas (Lérida) 



Vendo SVI 328 nuevo, con Datacasset- 
te, joystick, más de 30 programas 
como: Sasa, Ninja, etc. y revistas, mo- 
nitor f. verde Hantarex Boxer 12 pulga- 
das y amplificador de volumen por 
75.000 ptas. 

Javier 

Provenza, 433, 2 o , 1 a 
Tel. 318 76 20 
08025 Barcelona 



¡Oferta! Vendo ordenador Philips 
VG8010. Impecable, sin usar. Manuales 
y garantía originales. Además regalo 
listados de juegos, Revistas MSX, y 50 
juegos. Todo por 29.980 . 

Alberto Frías Pardo 
Julián Gayarre, 2 
Castejón (Navarra) 



Cambio o compro juegos. Escribir a: 

Alejandro Gregorio Panizo 
Belianes, 20 
28043 Madrid 



Intercambio programas en código má- 
quina para MSX y C-64. Buenos títulos. 

Rafael Sabariego 
Plaza Uzturre, 6, 8°C 
Tel. (943) 36 38 34 
Lasarte (Guipúzcoa) 



Intercambio juegos chicos/as. Tengo 
primeros títulos: Knight Lore, Alien 8, 
Pit Fall II, etc. Si os interesa escribir a: 

Laureano Ros 
Navaro de Haro 
Tel. 57 76 11 
Torre Pacheco (Murcia) 



Contacto con chicos-as de toda Espa- 
ña. Poseo más de 180 juegos (Profana- 
ron, Tiger, etc.) Escribir a: 

Luis A. de la Fuente 
Gran Capitán, 3-5, 2 o dcha. 

Salamanca 



Intercambio programas MSX, poseo 
primeros títulos del mercado. Escribir o 
llamar a: 

José Luis de la Pedraja 
José M" Pereda, 49, 1 o 
Tel. (942) 88 17 61 
Torrelavega (Cantabria) 

Vendo Data-Cartridge sin estrenar. Pre- 
cio a convenir, también vendo juegos. 
Primeras marcas del mercado de MSX. 



Armando Palet Martínez 
Tel. 676 12 44 
Torrejón de Ardoz 
Madrid 



Vendo grabador Sony TCM-2 nuevo 
con cable ordenador y un juego por 
7.000 ptas. contra reembolso. También 
intercambio programas de todo tipo 
para MSX. 

José Borrego 
Martí L'Huma, 7 
Olot 

17800 Gerona 



Vendo 9 juegos primeros títulos por 
3.500 ptas. Los títulos son: Knight Lore, 
A.R.M., Harrier Attack, Mutanta Monty, 
Manic Miner, Roload, Comando II, 
Quack a Jack y Roland Ahoy. Escribir a: 
Ignacio Aguilera Espejo 
Sevilla, 16 
Mairena de Aljarafe 
Sevilla 



Intercambio programas, últimos títu- 
los. Busco preferentemente: Taewon- 
do, The way of the Tiger, Circus Charly, 
Hyper Sports III y Mopiranger. 

Oscar Frades 
Avda. Arqueros, 49, 4°A 
28024 Madrid 



Vendo enciclopedia de la Informática 
Basic (Editorial Forum) 6 tomos Basic 
encuadernados más 3 tomos Basic Ad- 
vanced (Software para Apple, Commo- 
dore y MSX) Sesenta por ciento su va- 
lor real. Impecable estado. 

Jesús Blanch 
Central Telex Telégrafos 
Pl. País Valenciano 
Tel. (96) 363 34 18 (4 tarde) 
46002 Valencia 



Cambio programas MSX. Tengo Knight 
Lore y Ghostbuster. Me gustaría conse- 
guir Hero, The Way of the Tiger,... Es- 
cribir a: 

Pedro Ramírez Estrella 
Industria, 14, pta. 1 
Tel. (96) 323 40 81 
46022 Valencia 



Intercambio programas MSX. Poseo 
más de 200 títulos en código máquina. 
Escribir a: 

Emilio Rabásco Jiménez 
Murcia, 1 
Tel. (957) 25 03 41 
14010 Córdoba 



Intercambio todo tipo de programas sin 
interés económico. Poseo unos 70 (sólo 
Barcelona ciudad). 

Francisco José García 
Bonavista, 31-33 4 o V 
% 08012 Barcelona 
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Vendo el siguiente material: 3 cartu- 
chos (Socer, Hesware, Simon's Basic) y 
200 juegos tales como Rambo y Co- 
mando y utilidades tales como Simula- 
dor de Spectrum Busicalc, etc. También 
vendo las siguientes revistas: Nuevas 
tecnologías número 1, Biblioteca de In- 
formática n° 1, Lenguaje Máquina del 
Commodore 64, Muy ordenadores n° 
4,5 y 6, Commodore World n° 17,19,20 
al 26 y el 28; Commodore Magazine n° 
12,23 al 28; Basic n° 121 ; Input Commo- 
dore del 1 al 6 y el 8; Mi computer n° 
21,23,25; El ordenador personal n° 
24,22,41. Los juegos y cartuchos son 
del C-64. Todo aquel que tenga interés 
en los juegos, cartuchos, revistas que 
dirija sus cartas a: 

Miguel Angel Huelves García 
Entre Arroyos, 64, Ib 
Tel. 439 96 31 
28030 Madrid 



Vendo programas MSX. Tengo Knight 
Lore y Ghostbuster. Los vendo a 500 
ptas. cada uno. Dirigirse a: 

Pedro Angel Serrano Soguero 
Avda. Puerto 234, pta. 21 a 
46023 Valencia 



Desearía contactar con usarios de MSX 
de Jaén, para intercambiar ¡deas, pro- 
gramas (tengo Chuckie Egg, Grand Na- 
tional, Nick Neader, Champ (Ensambla- 
dor), y varias cintas de utilidades. Inte- 
resados dirigirse a: 

Pedro Peraba Montiel 
Jiménez Serrano, 2 
Tel. (953) 26 56 12 
Jaén 



Vendo cartucho de ampliación de me- 
moria HBM-16 de Sony por valor de 
4.000 ptas. 

Luis Santiago Moleón Garrido 
Traja no, 5, 5°F 
Tel. 20 57 77 
18002 Granada 



Desearía cambiar los programas Zax- 
xon y Jet Set Willy II por H.E.R.O. o Abu 
Simbel, Profanation. 

Sergi Bosch 
Tel. (93) 379 20 86 



Cambio y vendo programas MSX, po- 
seo todos los cartuchos de Konami y 
muchos cassettes. 

Javier Galán 
Tel. 332 54 29 
Barcelona 



Desearía intercambiar todo tipo de jue- 
gos para MSX. Interesados llamar a: 

Luis Crespo 
Avda. Mediterráneo, 28, 1°A 
Tel. (93) 718 59 99 
Ciudad Badia (Barcelona) 



amo 

Cambio cartuchos para video-juegos 
Phüps (Comecocos, Fórmula 1, Balon- 
cesto, Bolos, Marcianitos y Ajedrez, con 
su correspondiente memoria para jugar 
contra el aparato) por un monitor o te- 
levisor portátil. 

Antonio Veas González 
Tel. 330 09 17 
Barcelona 



Vendo ordenador Yashica YC-64 con 
64K de RAM y 16K VRAM. Comprado 
en Marzo de este año, por 30.000 ptas. 
Interesados llamar a: 

Félix 

Tel. (985) 21 79 45 
Oviedo 



Vendo ordenador Hit Bit Sony con car- 
tucho de ampliación 16K, por 30.000 
ptas. Para más información: 

José Manuel Trías Company 
Barne, 3 
Tel. 63 18 33 
Sóller (Mallorca) 



Vendo ordendor HB-55 P de Sony con 
ampliación de 16K por 23.000 ptas. o 
con ampliación de 64K por 33.000 ptas. 
Doy cintas L'n'RUN y 15 revistas MSX. 
Llamar a: 

Angel Ois 
Tel. (981)21 35 53 
La Coruña 



Intercambio programas MSX, Disc Wa- 
rrior, Alien 8, Jet Fighter por Jack the 
Nipper, Be. Grog Revenge II o The Dam- 
busters. Llamar o escribir a: 

José Vicente Mas 
Mateo Fial, 31 
Tel. (971)23 26 77 
Palma de Mallorca 
07013 Baleares 



Intercambio programas MSX. Poseo 
H.E.R.O, Ninja, Scentipede, Jack the 
Nipper, Profanation, etc. Interesados 
escribir a: 

Rafael Manresa 
Buenos Aires, 6, 2 dcha. 

30011 Murcia 



Vendo lápiz óptico 3.000 ptas., Interfa- 
ce MK2 1.000 ptas., Interface con soni- 
do 1.500 ptas., y muchísimos juegos 
originales a 995 ptas. cada uno. Todo 
para Spectrum. 

Alfonso Lucas Gómez 
Paseo Julio Urquijo, 32, 7°A 
Tel. 39 86 87 
Bidebieta 
20016 San Sebastián 



Vendo o cambio copión para SVI-728 
por 1000 ptas. o por uno de estos jue- 
gos para MSX: Camelot Warriors, 
Green Beret, The Way of the Tiger, Jack 
the Nipper, Rambo o Sobre Wulf. 



F. Artal Barba 
Avda. Madrid, 32 7°A 
20011 San Sebastián 
Guipúzcoa 



Intercambio programas en MSX. Entre 
otros: Time Pilot, Fitching Rider, Hiper 
3, Basketball, Baseball, etc. 

Guillem Carreras García 
Via Augusta, 320-322, 2 o 3 a 
Tel. 203 54 30 
08017 Barcelona 



Vendo ordenador Sony HB101P-48Kb. 
(comprado en enero) más ampliación 
Sony de 16Kb.. Todo en garantía por 
40.000 ptas. 

Diego D. González Rae 
Avda. Zamora 31, 2 o ¡zda. 
Tel. (986) 41 73 01 
Vigo (Pontevedra) 



Vendo o cambio juegos y programas 
del MSX. También compro unidad de 
diskettes de 3 1/2 pulgadas, precio a 
convenir. Escribir o llamar a: 

José Antonio Rodríguez 
Avda. America 66 
Tel. 246 61 79 
Madrid 



Cambio juegos de MSX. Tengo Zaxxon, 
H.E.R.O., Decathlon, etc. Escribir a: 

Eduardo Laplaza 
Junceda, 6 5 I 
08101 Rubí 

Intercambio y vendo ¡deas, trucos y 
programas para ordenadores MSX. 

Pedro José Ruiz Yelo 
Pza. Constitución, 1, 1°D edif. Alianza 
30820 Alcantarilla (Murcia) 

Busco ordenador MSX, unidad de dis- 
co, grabador cassette, joystick y demás 
periféricos, programas en cassette o 
disco y cualquier consejo. Soy comple- 
tamente novato. Espero ofertas. 

Armando 
Apartado 274 
Talavera 
45600 Toledo 

Desearía contactar con usuarios del 
MSX, para intercambiar opiniones, tru- 
cos, gráficos, sonido, preferiblemente 
de Vigo. 

Francisco J. Fernández Martínez 
Tel. (986) 41 77 07 
Vigo (Pontevedra) 

Cambio juegos MSX de los mejores: 
H.E.R.O., Gunfright, Yie Ar Kung Fu, Ri- 
ver Raid, etc. 

Miguel A. García Martínez 
Carrasco, 2, 7 o ¡zda. 
Tel. (965) 85 47 57 
Benidorm 
03500 Alicante 
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Dullin - Strassenburg 

MSX 

Lenguaje 
Máquina 



UN LIBRO DATA BECKER | 
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MSX LENGUAJE 
MAQUINA 



Autor: H. Dullin y H. St rasen - 
burg 

Editor: Ferré Moret S.A. 

Paginas: 305 

Precio: 

Muchas veces habremos sen- 
tido la necesidad de dar a nues- 
tros programas una rapidez 
que sólo con el BASIC no es 
posible conseguir. Para ello es 
necesario programar en len- 
guaje máquina. Sin embargo, 
hay que disponer de una infor- 
mación adecuada del micro- 
procesador /SO A. de sus ins- 
trucciones en código máquina y 
de su lenguaje ensamblador. 

Asimismo es conveniente te- 
ner herramientas básicas para 
poder desarrollar programas, 
como son un programa ensam- 
blador, un desensamblador, y 
un simulador del comporta- 
miento del programa, para po- 
der seguir su ejecución y en- 
contrar posibles errores. 

Todo esto que acabamos de 
mencioanr se encuentra inclui- 
do en el libro MSX Lenguaje 
Máquina. En él se nos ofrecen 
en primer lugar unos conceptos 
generales que comprenden las 
ideas de lenguaje máquina y de 
algunos sistemas de numera- 
ción: decimal, binario y hexa- 
decimal. 

A continuación se dedican 
tres capítulos al microprocesa- 
dor /SO A corazón de los orde- 
nadores MSX, explicándose su 
estructura interna y su juego de 
instrucciones. 

Se dedica a continuación un 
capítulo a técnicas de progra- 



mación en lenguaje máquina y 
otro, el último, a perspectivas 
futuras. 

El epílogo contiene útiles ta- 
blas de conversión y tablas de 
comandos. 

El tratamiento del tema es 
completo y didáctico. Los con- 
ceptos se explican de una for- 
ma muy clara y sencilla de for- 
ma que el lector, aunque carez- 
ca de conocimientos previos, 
puede aprender mucho y rápi- 
do. 

Al final de cada capítulo se 
incluyen ejercicios sencillos 
para que el lector pueda com- 
probar la asimilación de con- 
ceptos. 

Hay que destacar tres útiles 
programas cuyos listados apa- 
recen también en este libro. Se 
trata de un ensamblador, con 
el cual evitaremos tener que 
cargar los programas desde el 
BASIC utilizando los códigos 
hexadecimales (el tedioso pro- 
cedimiento de los DATA), pu- 
diendo usar los términos del 
ensamblador del Z80, más fá- 
ciles de manejar; hay también 
un desensamblador que nos 
permitirá ver los mnemónicos 
del programa escrito en memo- 
ria y un simulador paso a paso, 
con el cual podremos seguir la 
ejecución del programa ins- 
trucción por instrucción y des- 
cubrir así posibles errores. 



LENGUAJE MAQUINA 
PARA MSX, 
INTRODUCCION Y 
CONCEPTOS 
AVANZADOS 



Autor: Joe Pritchard 
Editor: Anaya 
Páginas: 240 
Precio: 

Dentro de la serie de libros 
dedicada por Anaya al sistema 
MSX, el que presentamos está 
dedicado a la programación en 
lenguaje máquina. 

Es una obra pensada para el 
usuario de MSX que no posee 
conocimientos previos de esta 
técnica de programación, y por 
ello, el nivel de las ideas expli- 
cadas es bastante básico y la 
forma de exponerlas muy sen- 
cilla, haciendo frecuente uso 
de ejemplos. 



El libro empieza por desa- 
rrollar una serie de principios 
básicos, con una introducción 
al MSX, y a la forma de calcu- 
lar de los ordenadores, cen- 
trándose luego en el micropro- 
cesador Z80, sus registros, mo- 
dos de direccionamiento, ins- 
trucciones de transferencia, de 
control y de entrada-salida. A 
lo largo de estos capítulos se in- 
cluyen frecuentemente ejem- 
plos, con los que probar y com- 
probar de manera práctica los 
resultados del último concepto 
explicado. 

Hay a continuación dos ca- 
pítulos de indudable interés. 
Uno de ellos está dedicado al 
procesador de video (VDP), y 
otro al generador programable 
de sonido (PSG). Es muy im- 
portante la inclusión de estos 
capítulos en cualquier libro que 
trate de programación en len- 
guaje máquina, ya que las ne- 
cesidades fundamentales para 
el uso de esta forma de progra- 
mación surgen de los gráficos y 
del sonido que deben ser ges- 
tionados rápidamente (sobre 
todo en juegos), y en ello el 
lenguaje máquina no tiene ri- 
val. 

El principal defecto que pue- 
de achacarse a este libro es la 
excesiva simplicidad en las 
ideas expuestas y en la forma 
de exponerlas. Ello puede ha- 
cer que el libro se quede corto 
para algún lector. 




MSX DE LA A A LA Z 



Autor: Varios 
Editor: RAMA 
Páginas: 233 
Precio: 

Se presenta en este libro un 
compendio ordenado alfabéti- 



MICRO 
GUIAS 



de la A a la Z 



ra-mcL 



camente de todas las palabras 
y términos que tienen relación 
con el MSX. 

En el podemos buscar con- 
ceptos generales, tales como 
notación hexadecimal, intér- 
prete, interrupción, etc., que* 
nos ayudarán a clarificar nues- 
tras ideas básicas. Están tam- 
bién incluidas las palabras del 
MSX-BASIC, acompañadas, 
cuando esto es posible, de un 
pequeño programa de ejem- 
plo, para ilustrar su uso. 

Asimismo, en caso de que 
decidamos pasar a programar 
el microprocesador, Z80A di- 
rectamente en código máqui- 
na, tenemos recopilada la defi- 
nición de cada uno de los mne- 
mónicos del lenguaje ensam- 
blador. 

Por último, aparecen tam- 
bién conceptos del sistema 
operativo en disco MSX-DOS, 
con esto se abarca de una ma- 
nera bastante global la totali- 
dad de los términos de interés 
para el programador. 

La explicación de cada pala- 
bra o idea es breve y no muy 
detallada. Al final de algunas 
definiciones se dan referencias 
a otras para que el lector las 
consulte. 

MSX de la A a la Z es una 
obra bastante completa como 
pequeño manual de consulta, 
ya que el abanico de conceptos 
que maneja es amplio. Sin em- 
bargo, dada la magnitud de la 
obra, se comprende que el es- 
pacio dedicado a cada palabra 
sea pequeño. No es en defini- 
tiva un libro para aprender, 
sino para recordar ideas y refe- 
rencias olvidadas o poco claras, 
o bien para iniciar al usuario 
sin ningún conocimiento previo 
en las ideas básicas. 
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EL MAS OCUPADO DE LA CASA. 



SX DE PHILIPS. 





■9 



Porque nadie puede resistirse a la tentación del 
MSX de Philips. A sus divertidos juegos de aventuras. 
A sus entretenidos programas educativos. O a los 
de oficina, como el "Home office". Capaz de hacer 
estadísticas, estudio de cuentas, contabilidad, etc. 



Y los programas específicos para hacer más fácil el 
trabajo al ama de casa. O al estudiante. Además, posee 
una amplísima gama de periféricos: impresoras, 
monitores, ratón, etc. Disfrute con el MSX de Philips. 
Siempre que no esté ocupado. 



PHILIPS 




Philips integra su futuro. 



PHILIPS 



MAS 
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